3

我正在编写 winform 应用程序,我在我的数据网格中调用过程。我有定义过程参数的方法

 public int Add_Nastavenie(out int typNastav, int nastavID, string hod)
    {
        ResetParameters();
        cmd.CommandText = "add_Nastav";
        cmd.CommandType = CommandType.StoredProcedure;

        SqlParameter sqlParameter;

        var sqlParameterOut = new SqlParameter("@TypNastav", SqlDbType.Int);
        sqlParameterOut.Direction = ParameterDirection.Output;


        sqlParameter = new SqlParameter("@NastavenieID", SqlDbType.Int);
        sqlParameter.Direction = ParameterDirection.Input;
        sqlParameter.Value = nastavID;
        cmd.Parameters.Add(sqlParameter);

        sqlParameter = new SqlParameter("@Hodnota", SqlDbType.NVarChar, 100);
        sqlParameter.Direction = ParameterDirection.Input;
        sqlParameter.Value = hod;
        cmd.Parameters.Add(sqlParameter);

        var sqlParameterRet = new SqlParameter("retValue", SqlDbType.Int);
        sqlParameterRet.Direction = ParameterDirection.ReturnValue;

        cmd.ExecuteNonQuery();
        typNastav = (int)sqlParameterOut.Value;
        return (int)cmd.Parameters["retvalue"].Value;

    }

然后我这样调用程序

 dataConnector.Add_Nastavenie(typNastav,nastavID,hod);

我有一个错误参数 1 必须使用 'out' 关键字传递

我将其更改为 dataConnector.Add_Nastavenie(out typNastav,nastavID,hod);

错误消失但应用程序不工作,程序什么也不做。

我的 try catch 异常显示:过程或函数“add_Nastav”需要参数“@TypNastav”,但未提供该参数。

有人可以帮助找到解决方案吗?谢谢 。

4

2 回答 2

5

您尚未添加OUTPUT存储过程所期望的参数:

 cmd.Parameters.Add(sqlParameterOut);
于 2013-08-07T13:37:00.693 回答
1

例子:

        SqlCommand com = new SqlCommand("update_outptu_Stock", connect.con);
            com.CommandType = CommandType.StoredProcedure;
            com.Parameters.AddWithValue("@cg_id ", 1);
            SqlParameter par = new SqlParameter("@id", SqlDbType.Int)
            {
                Direction = ParameterDirection.Output
            };

SQL:

Create proc update_outptu_Stock 
@cg_id int,
@id int output
as
begin
    insert into example(cg_id) values (@cg_id)
    set @id  = SCOPE_IDENTITY() -- get value of id created
end
Go

获取参数id:

var parvalue = id.value;
于 2013-08-07T13:52:50.567 回答