C#和Oracle 10g数据库调用存储过程

本文关键字:调用 存储过程 数据库 10g Oracle | 更新日期: 2023-09-27 18:21:40

我是一名C#+SQL server数据库开发人员。

现在我使用Oracle作为数据库。我有一个Oracle存储过程正在重新调整ref游标。


CREATE OR REPLACE PROCEDURE Get_Trans_Data ( p_return_cur OUT SYS_REFCURSOR)
IS
BEGIN
  OPEN p_return_cur FOR
  select * from test_tbl1 ;
END Get_Trans_Data;

仅使用Oledb如何访问此存储过程并将结果保存在数据集中?

我无法在Oledb中获得ref游标数据类型的选项。

C#和Oracle 10g数据库调用存储过程

您可以尝试这样的方法。无需为OUT添加参数。点击此处阅读更多

static void Read()
{
    using (var currentConnection = new OleDbConnection(
        "provider=MSDAORA;Data Source=orcl;User ID=db_test;Password=db_test;"))
    {
        currentConnection.Open();
        using (var myCommand = new OleDbCommand())
        {
            myCommand.Connection = currentConnection;
            myCommand.CommandType = CommandType.StoredProcedure;
            myCommand.CommandText = "Get_Data";
            myCommand.Parameters.Add(
                new OleDbParameter(
                    "firstParam",
                    OleDbType.Integer, 0, ParameterDirection.Input,
                    true, 0, 0, "", DataRowVersion.Default, Convert.DBNull));
            myCommand.Parameters[0].Value = 42;
            var myDataReader = myCommand.ExecuteReader();
            while (myDataReader.Read())
                for (int i = 0; i < myDataReader.FieldCount; i++)
                    Console.WriteLine(myDataReader.GetName(i));
        }
    }
}
CREATE OR REPLACE PROCEDURE Get_Data (
   p_return_cur OUT SYS_REFCURSOR,
   firstParam INTEGER) 
IS 
BEGIN 
  OPEN p_return_cur FOR select * from test; 
END Get_Data;