asp.net中oracle 存儲過程(圖文)
在大型數(shù)據(jù)庫系統(tǒng)中,存儲過程和觸發(fā)器具有很重要的作用。無論是存儲過程還是觸發(fā)器,都是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> /// 執(zhí)行oracle存儲過程返回多個結(jié)果集 /// </summary> /// <param name="strProcName">存儲過程名稱</param> /// <param name="ResultCount">返回個數(shù)</param> /// <param name="paras">參數(shù)</param> /// <returns>任意對象數(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)換出錯出錯!", 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);
以上內(nèi)容是通過代碼介紹了asp.net中oracle存儲過程。
接下來通過第二種的方式在給大家介紹下oracle存儲過程(圖文)。
請看下面方法、步驟
第一步:通過ORACLE自帶的 Net Manager 配置需要連接的數(shù)據(jù)庫,如COST
第二步:打開PL/SQL數(shù)據(jù)庫工具,屬于正確的用戶名和密碼以及選擇,點擊OK進入需要創(chuàng)建存儲過程的用戶下
第三步:了解一般存儲過程的格式
create or replace procedure 存儲過程名(param1 in type,param2 out type)
as
變量1 類型(值范圍);
變量2 類型(值范圍);
Begin
語句塊
Exception --異常處理
When others then
Rollback;
End;
第四步:在SQL輸入界面輸入需需要創(chuàng)建的存儲過程
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
注意事項
不能在一個存儲過程中刪除另一個存儲過程,只能調(diào)用另一個存儲過程
如果用create or replace procedure,創(chuàng)建存儲過程的時候注意不要與用戶下現(xiàn)有的存儲過程同名,造成現(xiàn)在存儲過程被覆蓋
存儲過程參數(shù)不帶取值范圍,in表示傳入,out表示輸出
以上通過兩種方式介紹哦oracle存儲過程,希望對大家有所幫助。
- C#利用ODP.net連接Oracle數(shù)據(jù)庫的操作方法
- .Net連接Oracle數(shù)據(jù)庫的實現(xiàn)代碼
- .net實現(xiàn)oracle數(shù)據(jù)庫中獲取新插入數(shù)據(jù)的id的方法
- .net連接oracle的3種實現(xiàn)方法
- asp.net中調(diào)用oracle存儲過程的方法
- ADO.Net對oracle數(shù)據(jù)庫操作的實例代碼
- Ibatis.net結(jié)合oracle批量刪除實現(xiàn)代碼
- 在.NetCore(C#)中使用ODP.NET Core+Dapper操作Oracle數(shù)據(jù)庫
相關(guān)文章
使用jQuery調(diào)用XML實現(xiàn)無刷新即時聊天
這篇文章主要介紹了使用jQuery調(diào)用XML實現(xiàn)無刷新即時聊天的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-08-08jQuery設(shè)置單選按鈕radio選中/不可用的實例代碼
這篇文章主要介紹了jQuery設(shè)置單選按鈕radio選中/不可用的實例代碼的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-06-06jQuery 可以拖動的div實現(xiàn)代碼 腳本之家修正版
最近研究了一下jQuery,覺得真的是一個很不錯的js庫,其他的不說,關(guān)鍵是有翔實的文檔,這點是非常關(guān)鍵的。2009-06-06ajax異步刷新實現(xiàn)更新數(shù)據(jù)庫
下面寫關(guān)于如何把無刷新的數(shù)據(jù)寫入到數(shù)據(jù)庫中,需要的朋友可以參考下2012-12-12