0
我试图执行一个存储过程并打印输出,但是当我运行下面的代码时,我得到错误,如“过程或函数'SPInsertLocal'期望参数'@RES',它没有提供。“过程或函数期望没有提供的参数。”
private void InsertPdtLocal(string code, string PON,string Qty)
{
string str = Properties.Settings.Default.conLocal;
SqlConnection con = new SqlConnection(str);
SqlCommand cmd = new SqlCommand("Execute SPInsertLocal @PON,@TCode,@Qty,@Type", con);
try
{
con.Open();
cmd.CommandTimeout = 150;
cmd.Parameters.AddWithValue("@PON", PON);
cmd.Parameters.AddWithValue("@Qty", Qty);
cmd.Parameters.AddWithValue("@TCode", code);
cmd.Parameters.AddWithValue("@Type", Globals.s_type);
SqlParameter output = new SqlParameter("@RES", SqlDbType.Int);
output.Direction = ParameterDirection.Output;
cmd.Parameters.Add(output);
cmd.ExecuteNonQuery();
con.Close();
int id = Convert.ToInt32(output.Value);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
我在做什么错在这里?
您的SQLCommand不包含@RES。你也可以使用新的SqlCommand(“SPInsertLocal”,con),然后指定CommandType = CommandType.StoredProcedure; –
您应该使用using语句以及SQLCommand实现IDisposible –