我正在编写 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”,但未提供该参数。
有人可以帮助找到解决方案吗?谢谢 。