C#調用ORACLE預存程序返回結果集及函數

來源:互聯網
上載者:User

oracle的預存程序返回記錄集,找到兩個ORACLE段都一樣,只是C#部份有點區別,都放上來,個人偏向使用用第一個。

 

C#調用ORACLE預存程序返回結果集及函數

ORACLE段:
首先在ORACLE建立PACKAGE和PACKAGE BODY,將在這裡面定義函數和預存程序返回結果集。
1:建立PACKAGE:
CREATE OR REPLACE package SCOTT.pk_wt
is
type mytype is ref cursor;
procedure p_wt(mycs out mytype);
function f_get(str in varchar2)
return varchar2;
end;
/
說明:其實PACKAGE只是個聲明罷了。我們在這裡定義了一個預存程序返回結集和一個函數,返回字串。

2:建立PACKAGE BODY:
CREATE OR REPLACE package BODY SCOTT.pk_wt
is
procedure p_wt(mycs out mytype)
is
begin
open mycs for select * from test;
end p_wt;

function f_get(str varchar2)
return varchar2
is
str_temp varchar2(100) := ''good luck!'';
begin
str_temp := str_temp || str;
return str_temp;
end f_get;

end pk_wt;
/
說明:這裡建立PACKAGE BODY是具體的說明和使用,將採用什麼方式實現。。

C#段:
在C#中代碼將分為兩部分,一部分是使用函數,另外一部分是使用結果集。
定義一個串連,從WEBCONFIG裡去取得:
private OracleConnection orcn=new OracleConnection(System.Configuration.ConfigurationSettings.AppSettings["scott"]);
C#調用ORACLE函數:
OracleCommand cmd=new OracleCommand("pk_wt.f_get",orcn);
cmd.CommandType=CommandType.StoredProcedure;
OracleParameter p1=new OracleParameter("str",OracleType.VarChar,10);
p1.Direction=System.Data.ParameterDirection.Input;
p1.Value=this.TextBox1.Text;
OracleParameter p2=new OracleParameter("result",OracleType.VarChar,100);
p2.Direction=System.Data.ParameterDirection.ReturnValue;
cmd.Parameters.Add(p1);
cmd.Parameters.Add(p2);
orcn.Open();
cmd.ExecuteNonQuery();
orcn.Close();
this.Button_function.Text=p2.Value.ToString();
其中RESULT是系統自訂的函數返回變數,特別要注意的是,函數的參數的傳回型別要指定,另外就是COMMAND類型也需要指定,另外和一般的預存程序沒什麼差別。

C#調用ORACLE返回結果集:
OracleCommand cmd=new OracleCommand("pk_wt.p_wt",orcn);
cmd.CommandType=CommandType.StoredProcedure;
OracleParameter p1=new OracleParameter("mycs",OracleType.Cursor);
p1.Direction=System.Data.ParameterDirection.Output;
cmd.Parameters.Add(p1);
OracleDataAdapter da=new OracleDataAdapter(cmd);
DataSet ds=new DataSet();
da.Fill(ds,"test");
this.DataGrid1.DataSource=ds;
this.DataGrid1.DataBind();
這裡沒什麼可說的類。。只是定義的資料類型是遊標,類型是OUTPUT,另外沒什麼了。。

oracle的預存程序返回記錄集

oracle的預存程序返回記錄集,關鍵之處是要用遊標。
  關於資料庫的遊標(cursor)大家肯定都接觸不少,我們可以通過OPEN,FETCH,CLOSE操作控制遊標進行各種方便的操作,這方面的例子我就不在重複了。我們現在要介紹的是遊標變數(cursor variable)。類似遊標,遊標變數也是指向一個查詢結果集的當前行。不同的是,遊標變數能為任何類型相似(type-compatible)的查詢開啟,而並不是綁定到某一個特定的查詢。通過遊標變數,你可以在資料庫的資料提取中獲得更多的方便。
  
  首先是建立表。
  
  CREATE TABLE LIHUAN.BILL_POINTS
  (
    POINTS_ID NUMBER(10,0) NOT NULL,
    CUSTOMER_ID NUMBER(10,0) NOT NULL,
    BILL_POINT_NO NUMBER(2,0) DEFAULT 1 NOT NULL,
    CONSTRAINT PK_BILL_POINTS PRIMARY KEY (POINTS_ID)
  )
  /
  
  其次,建PACKAGE
  CREATE OR REPLACE PACKAGE LIHUAN.YY_PKG_BILL_POINT_NO/*取得使用者的所有計費電序號*/
  IS
  TYPE T_CURSOR IS REF CURSOR;
  
    PROCEDURE BILL_POINT_NO(P_CUSTOMER_ID BILL_POINTS.CUSTOMER_ID%TYPE,
    Re_CURSOR OUT T_CURSOR);
  END;
  /
  
  再次,建PACKAGE BODY
  CREATE OR REPLACE PACKAGE BODY LIHUAN.YY_PKG_BILL_POINT_NO/*取得使用者的所有計費電序號*/
  IS
  
  PROCEDURE BILL_POINT_NO(P_CUSTOMER_ID BILL_POINTS.CUSTOMER_ID%TYPE,
    Re_CURSOR OUT T_CURSOR)
    IS
    V_CURSOR T_CURSOR;
    BEGIN
     OPEN V_CURSOR FOR
        select Bill_Point_No from BILL_POINTS where CUSTOMER_ID =P_CUSTOMER_ID;
        Re_CURSOR := V_CURSOR;
    END;
  END;
  /
  
  最後,在.NET中程式調用。
  public DataSet Bill_Point_No(string CUSTOMER_ID)//ok
   {
    DataSet dataset = new DataSet();
    Hashtable HT=new Hashtable();
    HT.Add(P_CUSTOMER_ID,CUSTOMER_ID);
    if(RunProcedure(Re_CURSOR,OracleType.Cursor,ref dataset,HT,bmsOracleUser+.YY_PKG_BILL_POINT_NO.BILL_POINT_NO,bmsOracleConnectionString))
    {
    ;
    }
    else
    {
    dataset=null;
    }
    return dataset;
   }
  
  public bool RunProcedure(string ReturnParameter,OracleType ParamType,ref DataSet Dataset,Hashtable HT ,string ProcedureName,string OracleConnection)
   {
    System.Data.OracleClient.OracleConnection dsconnection = new System.Data.OracleClient.OracleConnection(OracleConnection);
    System.Data.OracleClient.OracleCommand dacommand = new System.Data.OracleClient.OracleCommand(ProcedureName,dsconnection);
    dsconnection.Open();
    dacommand.CommandType=CommandType.StoredProcedure;
    IDictionaryEnumerator Enumerator;
    Enumerator = HT.GetEnumerator();
    object Value=null;
    OracleParameter OracleParam;
    OracleParam = dacommand.Parameters.Add(new OracleParameter(ReturnParameter,ParamType));
    OracleParam.Direction = ParameterDirection.Output;
    while(Enumerator.MoveNext())
    {
    Value = Enumerator.Value;
    OracleParam=dacommand.Parameters.Add(new OracleParameter(Enumerator.Key.ToString(), Value));
    }
    OracleDataAdapter ODAdapter=new OracleDataAdapter(dacommand);
        try
    {
    ODAdapter.Fill(Dataset);
     return true;
    }
    catch(System.Exception e)
    {
    e.ToString();
    return false;
    }
    finally
    {
    HT.Clear();
    dacommand.Parameters.Clear();
    dsconnection.Close();
    }

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.