欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

asp.net中oracle 存儲過程(圖文)

 更新時間:2015年08月12日 17:47:58   投稿:mrr  
存儲過程是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的sql語句集,經(jīng)過編譯存儲在數(shù)據(jù)庫中,用戶通過指定存儲過程的名字并給出參數(shù)(如果該存儲過程帶有參數(shù))來執(zhí)行它,下面小編給大家介紹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存儲過程,希望對大家有所幫助。

相關(guān)文章

最新評論