亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 11:50:28
字體:
來源:轉載
供稿:網友

在大型數據庫系統中,存儲過程和觸發器具有很重要的作用。無論是存儲過程還是觸發器,都是SQL 語句和流程控制語句的集合。

ORACLE代碼

CREATE OR REPLACE PROCEDURE gd_CURSOR(MYCS1 OUT SYS_REFCURSOR,MYCS2 OUT SYS_REFCURSOR,a out varchar)asBEGIN 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",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);

以上內容是通過代碼介紹了asp.net中oracle存儲過程。

接下來通過第二種的方式在給大家介紹下oracle存儲過程(圖文)。

請看下面方法、步驟

第一步:通過ORACLE自帶的 Net Manager 配置需要連接的數據庫,如COST

第二步:打開PL/SQL數據庫工具,屬于正確的用戶名和密碼以及選擇,點擊OK進入需要創建存儲過程的用戶下

第三步:了解一般存儲過程的格式

create or replace procedure 存儲過程名(param1 in type,param2 out type)
as
變量1 類型(值范圍);
變量2 類型(值范圍);
Begin
   語句塊
Exception --異常處理
   When others then
      Rollback;
End;

第四步:在SQL輸入界面輸入需需要創建的存儲過程

create or replace procedure sp_demo(param1 in varchar2,param2 out varchar2)/** 存儲過程實例*/ascnt 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

注意事項

不能在一個存儲過程中刪除另一個存儲過程,只能調用另一個存儲過程

如果用create or replace procedure,創建存儲過程的時候注意不要與用戶下現有的存儲過程同名,造成現在存儲過程被覆蓋
存儲過程參數不帶取值范圍,in表示傳入,out表示輸出

以上通過兩種方式介紹哦oracle存儲過程,希望對大家有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品美女免费| 欧美成人免费播放| 91中文在线观看| 成人黄色av免费在线观看| 欧美大尺度电影在线观看| 亚洲韩国欧洲国产日产av| 久久影视电视剧凤归四时歌| 久久亚洲精品网站| 在线精品国产成人综合| 一区二区中文字幕| 九色精品免费永久在线| 国产精品视频一区二区高潮| 成人综合国产精品| 韩国v欧美v日本v亚洲| 97在线精品视频| 97精品久久久中文字幕免费| 久久精品美女视频网站| 欧美电影免费观看高清完整| 日韩精品在线观看视频| 色综久久综合桃花网| 午夜精品久久久久久久99热| 97人人模人人爽人人喊中文字| 久久夜精品香蕉| 色樱桃影院亚洲精品影院| 高清一区二区三区四区五区| 国语自产精品视频在线看抢先版图片| 成人精品在线观看| 国产精品香蕉av| 亚洲欧美制服第一页| 国产一区二区动漫| 成人免费看黄网站| 日韩专区在线观看| 精品国产乱码久久久久久天美| 国产午夜精品一区理论片飘花| 2019日本中文字幕| 亚洲女人天堂色在线7777| 亚洲综合色激情五月| 最近2019年日本中文免费字幕| 日韩在线视频网| 欧洲美女7788成人免费视频| 在线播放日韩av| 黄色成人av网| 亚洲人a成www在线影院| 久久久久日韩精品久久久男男| 精品丝袜一区二区三区| 亚洲男子天堂网| 亚洲欧洲免费视频| 在线国产精品播放| 久久香蕉频线观| 亚洲国产成人在线播放| 黑丝美女久久久| 91精品综合视频| 欧美重口另类videos人妖| 国产999精品久久久影片官网| 国产盗摄xxxx视频xxx69| 国产精品69久久| 亚洲全黄一级网站| 日本一区二区在线免费播放| 精品久久久久久国产91| 国产精品入口免费视频一| 久久久免费在线观看| 国产女人18毛片水18精品| 亚洲美女www午夜| 91在线网站视频| 国产精品美女免费视频| 精品国产欧美一区二区五十路| 亚洲日韩中文字幕在线播放| 国产日韩亚洲欧美| 亚洲大尺度美女在线| 45www国产精品网站| 色妞色视频一区二区三区四区| 久久综合伊人77777| 尤物yw午夜国产精品视频明星| 国产在线拍揄自揄视频不卡99| 久久久精品国产一区二区| 亲子乱一区二区三区电影| 欧美精品www在线观看| 国产亚洲视频在线| 亚洲a一级视频| 亚洲第一精品福利| 国产欧美一区二区三区久久人妖| 国产日韩欧美另类| 国产精品视频色| 最近更新的2019中文字幕| 亚洲人成在线观看网站高清| 久久精品美女视频网站| 国内免费精品永久在线视频| 日韩一区视频在线| 国产日韩视频在线观看| 久久久国产成人精品| 日韩欧美极品在线观看| 欧洲精品在线视频| 91精品久久久久久| 精品福利在线视频| 一本一本久久a久久精品综合小说| 97精品国产97久久久久久免费| 98精品在线视频| 久久久久久久久久久av| 国产精品h在线观看| 欧美丝袜第一区| 亚洲人成绝费网站色www| 日韩精品极品视频免费观看| 欧美丝袜一区二区三区| 国产91精品网站| 久久久噜噜噜久久中文字免| 97碰碰碰免费色视频| 欧美黑人xxxⅹ高潮交| 欧美午夜精品久久久久久久| 日av在线播放中文不卡| 亚洲精品一区二区在线| 亚洲精品视频中文字幕| 久久精品在线播放| 国产亚洲激情在线| 亚洲最大福利视频| 福利二区91精品bt7086| 国产精品美乳在线观看| 成人美女免费网站视频| 欧美激情国产高清| 欧美午夜片在线免费观看| 最好看的2019的中文字幕视频| 国产精品综合不卡av| 美女av一区二区| 亚洲色图50p| 日韩亚洲综合在线| 国产中文字幕91| 国产精品久久久久久久7电影| 色婷婷综合成人av| 久久久久久com| 国产精品www| 韩国精品久久久999| 亚洲国产精品人久久电影| 久久久99久久精品女同性| 欧美色视频日本高清在线观看| 国产成人精品久久亚洲高清不卡| 久久久久免费视频| 国产精品露脸自拍| 91性高湖久久久久久久久_久久99| 亚洲福利视频在线| 国产欧美精品一区二区三区介绍| 久久人人爽人人| 欧日韩不卡在线视频| 国产成人福利夜色影视| 亚洲精品自拍第一页| 久久精品国产96久久久香蕉| 日韩电影免费观看在线| 国产精品海角社区在线观看| www.欧美精品| 亚洲欧美在线看| 亚洲欧美综合区自拍另类| 日韩欧美aaa| 性欧美在线看片a免费观看| 91理论片午午论夜理片久久| 国模极品一区二区三区| 懂色av中文一区二区三区天美| 久久影视电视剧凤归四时歌| 日本aⅴ大伊香蕉精品视频| 欧美重口另类videos人妖| 国产精品美乳一区二区免费| 91国偷自产一区二区三区的观看方式| 91美女片黄在线观| 欧美激情免费视频| 黑人巨大精品欧美一区免费视频| 欧美大肥婆大肥bbbbb| 91亚洲精品在线|