asp.net中调用oracle存储过程的方法
存储过程(StoredProcedure)是在大型数据库系统中,一组为了完成特定功能的SQL语句集,存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
不多说了,本文通过两种方法介绍asp.net中调用oracle存储过程的方法,具体内容请看下面代码。
调用oracle存储过程方法一:
ORACLE代码
CREATEORREPLACEPROCEDUREgd_CURSOR(MYCS1OUTSYS_REFCURSOR,MYCS2OUTSYS_REFCURSOR,aoutvarchar)as BEGIN a:='test'; OPENMYCS1FOR SELECT1fromdual; OPENMYCS2FOR SELECT2fromdual; END;
C#代码
///<summary>
///执行oracle存储过程返回多个结果集
///</summary>
///<paramname="strProcName">存储过程名称</param>
///<paramname="ResultCount">返回个数</param>
///<paramname="paras">参数</param>
///<returns>任意对象数组</returns>
publicobject[]ExcuteProc_N_Result(stringstrProcName,intResultCount,paramsOracleParameter[]paras)
{
using(OracleConnectionconn=newOracleConnection("UserID=用户名;Password=密码;DataSource=数据库;"))
{
OracleCommandcmd=newOracleCommand(strProcName,conn);
if(paras!=null&¶s.Length>0)
{
for(intj=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();
inti=0;
//intnOutputParametersCount=0;
object[]objResult=newobject[ResultCount];
foreach(OracleParameterpincmd.Parameters)
{
if(p.Direction==ParameterDirection.Output||p.Direction==ParameterDirection.InputOutput)
{
if(p.ValueisOracleDataReader)
{
OracleDataReaderreader=p.ValueasOracleDataReader;
objResult[i++]=ConvertDataReaderToDataTable(reader);
}
else
{
objResult[i++]=p.Value;
}
}
}
returnobjResult;
}
}
///<summary>
///将DataReader转为DataTable
///</summary>
///<paramname="DataReader">OleDbDataReader</param>
protectedDataTableConvertDataReaderToDataTable(OracleDataReaderreader)
{
DataTableobjDataTable=newDataTable("TmpDataTable");
try
{
intintFieldCount=reader.FieldCount;//获取当前行中的列数;
for(intintCounter=0;intCounter<=intFieldCount-1;intCounter++)
{
objDataTable.Columns.Add(reader.GetName(intCounter),reader.GetFieldType(intCounter));
}
//populatedatatable
objDataTable.BeginLoadData();
//object[]objValues=newobject[intFieldCount-1];
object[]objValues=newobject[intFieldCount];
while(reader.Read())
{
reader.GetValues(objValues);
objDataTable.LoadDataRow(objValues,true);
}
reader.Close();
objDataTable.EndLoadData();
returnobjDataTable;
}
catch(Exceptionex)
{
thrownewException("转换出错出错!",ex);
}
}
调用方法
OracleParameter[]oracleParameter=newOracleParameter[]{
newOracleParameter("MYCS1",OracleType.Cursor),
newOracleParameter("MYCS2",OracleType.Cursor),
newOracleParameter("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存储过程方法二:
存储过程结构如下:
CreateorReplaceProcedurexx_yy ( i_OrderIDinnumber, i_ReturnValueoutnumber ) is v_RealValuenumber; v_TotalValuenumber; v_AdvendorIDnumber; begin 自己写就行 end;
下面讲一下调用:
表结构
createtableORDERTABLE ( ORDERIDNUMBERnotnull, TEXTNUMBERnotnull )
存储过程
( i_OrderIDinnumber, i_ReturnValueoutnumber ) is spassordertable.text%type; begin selecttextintospassfromordertablewhereorderid=i_OrderID; i_ReturnValue:=spass; exception whenno_data_found theni_ReturnValue:=-1; end;
源码:
usingSystem.Data.OracleClient;//(别忘了添加)
OracleConnectionOraclecon=newOracleConnection("Password=dloco;UserID=dloco;DataSource=dloco;");
OracleCommandmyCMD=newOracleCommand();
OracleParameter[]parameters={newOracleParameter("i_OrderID",OracleType.Number,10),newOracleParameter("i_ReturnValue",OracleType.Number,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();
stringresult=myCMD.Parameters["i_ReturnValue"].Value.ToString();
MessageBox.Show(result);
Oraclecon.Close();
以上就是asp.net中调用oracle存储过程的全部内容,希望对大家有所帮助。