asp.net中调用oracle存储过程的方法
发布时间:2020-05-24 04:56:40 所属栏目:MsSql 来源:互联网
导读:存储过程(StoredProcedure)是在大型数据库系统中,一组为了完成特定功能的SQL语句集,存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来
|
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。 存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。 不多说了,本文通过两种方法介绍asp.net中调用oracle存储过程的方法,具体内容请看下面代码。 调用oracle存储过程方法一: 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",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);
调用oracle存储过程方法二: 存储过程结构如下: Create or Replace Procedure xx_yy ( i_OrderID in number,i_ReturnValue out number ) is v_RealValue number; v_TotalValue number; v_AdvendorID number; begin 自己写就行 end; 下面讲一下调用: 表结构 create table ORDERTABLE ( ORDERID NUMBER not null,TEXT NUMBER not null ) 存储过程 ( i_OrderID in number,i_ReturnValue out number ) is spass ordertable.text%type; begin select text into spass from ordertable where orderid=i_OrderID; i_ReturnValue:=spass; exception when no_data_found then i_ReturnValue:=-1; end; 源码:
using System.Data .OracleClient ;//(别忘了添加)
OracleConnection Oraclecon = new OracleConnection ("Password=dloco;User ID=dloco;Data Source=dloco;");
OracleCommand myCMD = new OracleCommand();
OracleParameter[] parameters = { new OracleParameter("i_OrderID",OracleType.Number,10),new OracleParameter("i_ReturnValue",10 )};
parameters[0].Value = 1;
parameters[1].Direction = ParameterDirection.Output;
myCMD.Connection = Oraclecon;
myCMD.CommandType = CommandType.StoredProcedure;
myCMD.CommandText = "dloco.xx_yy";
myCMD.Parameters .Add (parameters[0]);
myCMD.Parameters .Add (parameters[1]);
myCMD.Connection.Open();
myCMD.ExecuteNonQuery();
string result=myCMD.Parameters["i_ReturnValue"].Value.ToString();
MessageBox.Show (result);
Oraclecon.Close();
以上就是asp.net中调用oracle存储过程的全部内容,希望对大家有所帮助。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- mysql中使用instr进行模糊查询方法介绍
- sql-server-2005 – 根据参数选择更新报表参数? (SSRS)
- SQL在顶部有一个特定记录,下面是其他所有记录
- mysql备份脚本 mysqldump使用方法详解
- sql – 如何在oracle中为每个重复的id行获取一条记录?
- sql-server-2005 – SAS读取sql server 2005中的位数据类型
- sql-server – SQL Server中的复合索引与INCLUDE覆盖索引
- sql – Redshift:从字符串执行动态查询
- 与使用SQL Server匹配字符串的“=”相似
- mysql ERROR 1044 (42000): Access denied for user @local
推荐文章
站长推荐
- sql – 创建只能查看一个数据库的用户,只能从中选
- sql – 为什么在现有列中添加可空的默认约束需要
- sql-server – 旧的row_number()和SQL Server中基
- sql-server – Visual Studio 2010和Sql Server
- sql – 存储多个位 – 我应该使用多列还是单个位
- 阿里云服务器安装配置redis的方法并且加入到开机
- sql-server – DL380p-Gen8 D2700适用于SQL 2012
- sql-server – a = 0和b = 0的性能和… z = 0 vs
- linq-to-sql – Linq:简单布尔函数返回linq异常
- sql – 在Access中尝试CREATE VIEW会出现“CREAT
热点阅读
