1

我在 ASP.NET (C#) 应用程序中继承了作者Microsoft.Practices.EnterpriseLibrary.Data library使用System.Data.OracleClient. 该函数使用存储过程形成数据库。itemName, 和openDate是函数接受的字符串参数。PKG_AUCTION_ITEMS.IsAuctionItem是存储过程函数名。

这是我收到的代码:

    string result = String.Empty;

    Database db = DatabaseFactory.CreateDatabase("OraData");
    using (DbCommand cmdDB = db.GetStoredProcCommand("PKG_AUCTION_ITEMS.IsAuctionItem"))
    {
        db.AddInParameter(cmdDB, "vItemName", DbType.String, itemName);
        db.AddInParameter(cmdDB, "vOpenDate", DbType.String, openDate);
        db.AddParameter(cmdDB, "ret", DbType.String, 2, ParameterDirection.ReturnValue, false, 0, 0, null, DataRowVersion.Current, null);


        db.ExecuteNonQuery(cmdDB);
        result = cmdDB.Parameters["ret"].Value.ToString();
    }

这是我的代码:(connstr是连接字符串)

    string result = String.Empty;
    OracleConnection conn = new OracleConnection(connstr);
    OracleCommand cmd = new OracleCommand("PKG_AUCTION_ITEMS.IsAuctionItem",conn);
    myCmd.CommandType = CommandType.StoredProcedure;

    using (myCmd)
    {
        myCmd.Parameters.AddWithValue("vItemName", itemName);
        myCmd.Parameters.AddWithValue("vOpenDate", openDate);
        myCmd.Parameters.AddWithValue("ret", ???);
        myCmd.ExecuteNonQuery();
        result = myCmd.Parameters["ret"].Value.ToString();
    }

我不明白 AddInParameter 和 AddParameter 之间的区别是什么,以及这一行的作用:

db.AddParameter(cmdDB, "ret", DbType.String, 2, ParameterDirection.ReturnValue, false, 0, 0, null, DataRowVersion.Current, null);

我在正确的轨道上吗?有人可以帮忙吗?谢谢

4

2 回答 2

1

db.AddParameter 在这种情况下添加了一个输出参数。您需要让 db 客户端库知道您希望从 sproc 调用中获取返回值。因此调用 AddParameter。db.AddInParameter 添加一个参数,该参数只是一个内参数。在它是使用 ParameterDirection.Input 的 db.AddParameter 的快捷方式。有关 AddInParameter 与 AddParameter 的讨论,请参阅http://blogs.x2line.com/al/archive/2006/03/25/1579.aspx

类似地,使用 OracleClient,AddWithValue 就像 AddInParameter——当您已经知道值时用于输入参数的快捷方式。由于根据定义,返回值是一个输出参数,因此您不能使用 AddWithValue。您需要改用 Parameters.Add()。

现在,回到您的主要问题:使用 OracleClient 的等效代码是什么。是这样的:

string result = String.Empty;
OracleConnection conn = new OracleConnection(connstr);
OracleCommand cmd = new OracleCommand("PKG_AUCTION_ITEMS.IsAuctionItem",conn);
myCmd.CommandType = CommandType.StoredProcedure;

using (myCmd)
{
    myCmd.Parameters.AddWithValue("vItemName", itemName);
    myCmd.Parameters.AddWithValue("vOpenDate", openDate);

    // depending on whether you're using Microsoft's or Oracle's ODP, you 
    // may need to use OracleType.Varchar instead of OracleDbType.Varchar2.
    // See http://forums.asp.net/t/1002097.aspx for more details.
    OracleParameter retval = new OracleParameter("ret",OracleDbType.Varchar2,2);
    retval.Direction = ParameterDirection.ReturnValue;
    myCmd.Parameters.Add(retval);

    myCmd.ExecuteNonQuery();
    result = myCmd.Parameters["ret"].Value.ToString();
}
于 2009-09-18T20:55:14.507 回答
0

我们实际上更明确地进行参数的配置,像这样

System.Data.OracleClient.OracleCommand command = new System.Data.OracleClient.OracleCommand("PACKAGE_NAME.STORED_NAME");
command.CommandType = System.Data.CommandType.StoredProcedure;

System.Data.OracleClient.OracleParameter param;
param = new System.Data.OracleClient.OracleParameter("PARAM_NAME_ID", System.Data.OracleClient.OracleType.Number);
param.Value = id;
command.Parameters.Add(param);

param = new System.Data.OracleClient.OracleParameter("PARAM_NAME_RETURN_COUNT", System.Data.OracleClient.OracleType.Number);
param.Direction = System.Data.ParameterDirection.Output;
command.Parameters.Add(param);
...

您会看到,我们为要返回的参数显式分配了一个属性方向。第一个获取变量“id”的值,并且是传递给存储过程的参数。

第二个由存储过程返回,因此没有为该参数值分配值,方向设置为"System.Data.ParameterDirection.Output"

于 2009-09-19T16:47:36.877 回答