2

我是Oracle 编程的ac#SQL Server 开发人员。下面的代码用于将 cmdText 设置为:“select * from myTable”。我现在想把它放在一个存储过程中,我需要有关如何编写这个 Oracle 存储过程并将结果放入我的 c# 代码中的 DataTable 的帮助。谢谢。代码:

private DbProviderFactory DbFactory
    {
        get
        {
            dbProviderFactory = dbProviderFactory  ?? DbProviderFactories.GetFactory(providerInvariantName);
            return dbProviderFactory;
        }
    }

public DataTable ExecDataTable(string cmdText, params IDataParameter[] cmdParams)
    {
        DataTable resultDT = new DataTable();

        using (DbConnection dbConn = DbFactory.CreateConnection())
        {
            dbConn.ConnectionString = connectionString;
            using (DbCommand dbCmd = DbFactory.CreateCommand())
            {
                dbCmd.CommandText = cmdText;
                dbCmd.Connection = dbConn;

                try
                {
                    dbConn.Open();

                    if (cmdParams != null)
                    {
                        dbCmd.Parameters.AddRange(cmdParams);
                    }

                    using (DbDataAdapter dbDA = DbFactory.CreateDataAdapter())
                    {
                        dbDA.SelectCommand = dbCmd;
                        dbDA.Fill(resultDT);
                    }
                }
                finally
                {
                    dbConn.Close();
                }
            }
        }
        return resultDT;
    }

注意:connectionString、providerInvariantName 是之前在代码中设置的。

此外,任何关于重构我的代码的建议都值得赞赏,这是我为支持 ODP.net 以及现场需要的与 Oracle 的 ODBC 连接而采取的方法。

更新

我可以使用:

new Oracle.DataAccess.Client.OracleParameter("result", Oracle.DataAccess.Client.OracleDbType.RefCursor, ParameterDirection.Output);

但是,我似乎无法获得使用DbParameter 或 IDataParameter工作的通用解决方案我如何做到这一点以支持 ODBC 和 ODP.net

4

2 回答 2

2

你真的要支持ODBC吗?否则只使用 ODP.Net,它优化了对 Oracle 的访问。从 Oracle 获取数据的最有效方法是使用 ref 游标,您应该学会使用它。

create or replace
PROCEDURE  SP_GET_TBL (o_rc OUT sys_refcursor) AS
   open o_rc for
        select Col1, Col2, Col3 from Tbl;       
END SP_GET_TBL;
于 2009-08-20T10:59:32.537 回答
1

设置 CommandType 属性,

dbCmd.CommandType=StoredProcedure;

填充方法隐式打开和关闭数据库连接,因此无需打开和关闭数据库连接。

使用cmd.Parameter.AddWithValue()方法推送参数和值。

于 2009-08-20T10:28:27.123 回答