存储过程是在大型数据库系统中,一组为了完成特定功能的 sql 语句集,经过编译存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它,下面小编给大家介绍 asp.net 中 oracle 存储过程,需要的朋友可以参考下
Oracle Database,又名 Oracle RDBMS,或简称 Oracle。是甲骨文公司的一款关系数据库管理系统。到目前仍在数据库市场上占有主要份额。
在大型数据库系统中,存储过程和触发器具有很重要的作用。无论是存储过程还是触发器,都是 SQL 语句和流程控制语句的集合。
ORACLE 代码
- CREATE OR REPLACE PROCEDURE gd_CURSOR(MYCS1 OUT SYS_REFCURSOR,MYCS2 OUT SYS_REFCURSOR,a out varchar)as
- BEGIN
- a:='test';
- OPEN MYCS1 FOR
- SELECT 1 from dual;
- OPEN MYCS2 FOR
- SELECT 2 from dual;
- END;
C# 代码
- /// <summary>
- /// 执行oracle存储过程返回多个结果集
- /// </summary>
- /// <param name="strProcName">存储过程名称</param>
- /// <param name="ResultCount">返回个数</param>
- /// <param name="paras">参数</param>
- /// <returns>任意对象数组</returns>
- public object[] ExcuteProc_N_Result(string strProcName, int ResultCount, params OracleParameter[] paras)
- {
- using (OracleConnection conn = new OracleConnection("User ID=用户名;Password=密码;Data Source=数据库;"))
- {
- OracleCommand cmd = new OracleCommand(strProcName, conn);
- if (paras != null && paras.Length > 0)
- {
- for (int j = 0; j < paras.Length; j++)
- {
- if (paras[j].Value == null)
- {
- paras[j].Value = DBNull.Value;
- }
- }
- }
- cmd.Parameters.AddRange(paras);
- cmd.CommandType = CommandType.StoredProcedure;
- conn.Open();
- cmd.ExecuteNonQuery();
- int i = 0;
- //int nOutputParametersCount = 0;
- object[] objResult = new object[ResultCount];
- foreach (OracleParameter p in cmd.Parameters)
- {
- if (p.Direction == ParameterDirection.Output || p.Direction == ParameterDirection.InputOutput)
- {
- if (p.Value is OracleDataReader)
- {
- OracleDataReader reader = p.Value as OracleDataReader;
- objResult[i++] = ConvertDataReaderToDataTable(reader);
- }
- else
- {
- objResult[i++] = p.Value;
- }
- }
- }
- return objResult;
- }
- }
- /// <summary>
- /// 将DataReader 转为 DataTable
- /// </summary>
- /// <param name="DataReader">OleDbDataReader</param>
- protected DataTable ConvertDataReaderToDataTable(OracleDataReader reader)
- {
- DataTable objDataTable = new DataTable("TmpDataTable");
- try
- {
- int intFieldCount = reader.FieldCount;//获取当前行中的列数;
- for (int intCounter = 0; intCounter <= intFieldCount - 1; intCounter++)
- {
- objDataTable.Columns.Add(reader.GetName(intCounter), reader.GetFieldType(intCounter));
- }
- //populate datatable
- objDataTable.BeginLoadData();
- //object[] objValues = new object[intFieldCount -1];
- object[] objValues = new object[intFieldCount];
- while (reader.Read())
- {
- reader.GetValues(objValues);
- objDataTable.LoadDataRow(objValues, true);
- }
- reader.Close();
- objDataTable.EndLoadData();
- return objDataTable;
- }
- catch (Exception ex)
- {
- throw new Exception("转换出错出错!", ex);
- }
- }
调用方法
- OracleParameter[] oracleParameter = new OracleParameter[]{
- new OracleParameter("MYCS1",OracleType.Cursor),
- new OracleParameter("MYCS2",OracleType.Cursor),
- new OracleParameter("a",OracleType.VarChar,200),
- };
- oracleParameter[0].Direction = ParameterDirection.Output;
- oracleParameter[1].Direction = ParameterDirection.Output;
- oracleParameter[2].Direction = ParameterDirection.Output;
- object[] xxx = ExcuteProc_N_Result("gd_CURSOR", 3, oracleParameter);
以上内容是通过代码介绍了 asp.net 中 oracle 存储过程。
接下来通过第二种的方式在给大家介绍下 oracle 存储过程(图文)。
请看下面方法、步骤
第一步:通过 ORACLE 自带的 Net Manager 配置需要连接的数据库,如 COST
第二步:打开 PL/SQL 数据库工具,属于正确的用户名和密码以及选择,点击 OK 进入需要创建存储过程的用户下
第三步:了解一般存储过程的格式
create or replace procedure 存储过程名(param1 in type,param2 out type)
as
变量 1 类型(值范围);
变量 2 类型(值范围);
Begin
语句块
Exception -- 异常处理
When others then
Rollback;
End;
第四步:在 SQL 输入界面输入需需要创建的存储过程
- create or replace procedure sp_demo(param1 in varchar2,param2 out varchar2)
- /*
- * 存储过程实例
- */
- as
- cnt int;
- rst varchar2(100)
- Begin
- Select count(*) into cst from Tab_Demo where Col_Value = param1;
- If (cst > 0) then --判断条件
- param2 := '有匹配的值';
- Else
- param2 := '无匹配的值';
- End if;
- Exception
- When others then
- Rollback;
- End;
如下图
第五步:测试刚才编写的存储过程
exec sp_demo('男');
END
注意事项
不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程
如果用 create or replace procedure,创建存储过程的时候注意不要与用户下现有的存储过程同名,造成现在存储过程被覆盖
存储过程参数不带取值范围,in 表示传入,out 表示输出
以上通过两种方式介绍哦 oracle 存储过程,希望对大家有所帮助。
来源: http://www.phperz.com/article/17/0320/269962.html