asp oracle存储过程,asp.net中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#代码

///

/// 执行oracle存储过程返回多个结果集

///

/// 存储过程名称

/// 返回个数

/// 参数

/// 任意对象数组

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;

}

}

///

/// 将DataReader 转为 DataTable

///

/// OleDbDataReader

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

f4187ae30201ac815f0a626c48fa1bb4.png

第二步:打开PL/SQL数据库工具,属于正确的用户名和密码以及选择,点击OK进入需要创建存储过程的用户下

275ac573b5a7ed56aa1c48e9eddfaca4.png

第三步:了解一般存储过程的格式

create or replace procedure 存储过程名(param1 in type,param2 out type)

as

变量1 类型(值范围);

变量2 类型(值范围);

Begin

语句块

Exception --异常处理

When others then

Rollback;

End;

0b7c3fd1d737a84f3dc68e4771e1173c.png

第四步:在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;

如下图

5c853e70d33488720a1a134fffc01c66.png

第五步:测试刚才编写的存储过程

exec sp_demo('男');

58a6bf4e88ca38b46e1608fe94606f61.png

END

注意事项

不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程

如果用create or replace procedure,创建存储过程的时候注意不要与用户下现有的存储过程同名,造成现在存储过程被覆盖

存储过程参数不带取值范围,in表示传入,out表示输出

以上通过两种方式介绍哦oracle存储过程,希望对大家有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值