我没看到为什么我的更新语句实际上没有更新。这就是我所拥有的:
private void submit_button_Click(object sender, EventArgs e)
{
string insert = insertbox.Text;
SqlParameter param2 = new SqlParameter("@param2", SqlDbType.Text);
param2.Value = insert;
var connlink = new SqlConnection("Data Source=.\\SQLEXPRESS;AttachDbFilename=C:\\Program Files\\Microsoft SQL Server\\MSSQL.2\\MSSQL\\Data\\Inserts.mdf;Integrated Security=True;Connect Timeout=30;User Instance=True");
var cmd1 = new SqlCommand(@"SELECT qty_onhand FROM [insert] WHERE (Name LIKE @param2)", connlink);
connlink.Open();
cmd1.Parameters.Add(param2);
var onhand = Convert.ToInt16(cmd1.ExecuteScalar());
// The param2 in the statement passes fine and returns the value into "onhand".
// Below, the parameters don't seem to be passed. There is no error but the record isn't updated.
int new_onhand = Convert.ToInt16(qtybox1.Text);
Convert.ToInt16(onhand);
new_onhand = onhand - new_onhand;
SqlParameter param1 = new SqlParameter("@param1", SqlDbType.SmallInt);
param1.Value = new_onhand;
SqlParameter param3 = new SqlParameter("@param3", SqlDbType.Text);
param3.Value = param2.ToString();
var cmd = new SqlCommand(@"UPDATE [insert] SET qty_onhand = @param1 WHERE (Name LIKE @param3)", connlink);
cmd.CommandType = CommandType.Text;
cmd.Parameters.Add(param1);
cmd.Parameters.Add(param3);
cmd.ExecuteNonQuery();
connlink.Close();
}
我不确定为什么一个有效而另一个无效。
答案 0 :(得分:1)
通过在param2上调用ToString来设置param3
的值:param3.Value = param2.ToString();
在SqlParameter上调用ToString会返回参数名称。在我们的例子中,它返回" @ param2"作为字符串,而不是它的值。尝试使用param2.Value
。
或者实际上是insert
,因为你写了param2.Value = insert;
。
答案 1 :(得分:0)
下面的行看起来对我不正确,因为param2的类型为SqlParameter,并且您使用param2.ToString()作为param3.value的值
SqlParameter param3 = new SqlParameter("@param3", SqlDbType.Text);
**param3.Value = param2.ToString();**