存儲(chǔ)過程是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL 語句集,存儲(chǔ)在數(shù)據(jù)庫中經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯,用戶通過指定存儲(chǔ)過程的名字并給出參數(shù)來執(zhí)行它,下面給大家介紹下asp.net中調(diào)用oracle存儲(chǔ)過程的方法,需要的朋友可以參考下
存儲(chǔ)過程(Stored Procedure)是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL 語句集,存儲(chǔ)在數(shù)據(jù)庫中經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯,用戶通過指定存儲(chǔ)過程的名字并給出參數(shù)(如果該存儲(chǔ)過程帶有參數(shù))來執(zhí)行它。
存儲(chǔ)過程是數(shù)據(jù)庫中的一個(gè)重要對(duì)象,任何一個(gè)設(shè)計(jì)良好的數(shù)據(jù)庫應(yīng)用程序都應(yīng)該用到存儲(chǔ)過程。
不多說了,本文通過兩種方法介紹asp.net中調(diào)用oracle存儲(chǔ)過程的方法,具體內(nèi)容請(qǐng)看下面代碼。
調(diào)用oracle存儲(chǔ)過程方法一:
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>
- /// 執(zhí)行oracle存儲(chǔ)過程返回多個(gè)結(jié)果集
- /// </summary>
- /// <param name="strProcName">存儲(chǔ)過程名稱</param>
- /// <param name="ResultCount">返回個(gè)數(shù)</param>
- /// <param name="paras">參數(shù)</param>
- /// <returns>任意對(duì)象數(shù)組</returns>
- public object[] ExcuteProc_N_Result(string strProcName, int ResultCount, params OracleParameter[] paras)
- {
- using (OracleConnection conn = new OracleConnection("User ID=用戶名;Password=密碼;Data Source=數(shù)據(jù)庫;"))
- {
- 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 轉(zhuǎn)為 DataTable
- /// </summary>
- /// <param name="DataReader">OleDbDataReader</param>
- protected DataTable ConvertDataReaderToDataTable(OracleDataReader reader)
- {
- DataTable objDataTable = new DataTable("TmpDataTable");
- try
- {
- int intFieldCount = reader.FieldCount;//獲取當(dāng)前行中的列數(shù);
- 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("轉(zhuǎn)換出錯(cuò)出錯(cuò)!", ex);
- }
- }
調(diào)用方法
- 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);
調(diào)用oracle存儲(chǔ)過程方法二:
存儲(chǔ)過程結(jié)構(gòu)如下:
- 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;
下面講一下調(diào)用:
表結(jié)構(gòu)
- create table ORDERTABLE
- (
- ORDERID NUMBER not null,
- TEXT NUMBER not null
- )
存儲(chǔ)過程
- (
- 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",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();
- string result=myCMD.Parameters["i_ReturnValue"].Value.ToString();
- MessageBox.Show (result);
- Oraclecon.Close();
以上就是asp.net中調(diào)用oracle存儲(chǔ)過程的全部內(nèi)容,希望對(duì)大家有所幫助。
|
新聞熱點(diǎn)
疑難解答
圖片精選