yas*_* sh 6 c# sql sql-server visual-studio-2008
变量名'@LockState'已经声明.变量名在查询批处理或存储过程中必须是唯一的.
当我执行下面的代码时,上面的错误出现在第二个@LockState上的sql参数上.
private void btn_lock2_Click(object sender, EventArgs e)
{
rwd.command = new SqlCommand();
rwd.command.Connection = rwd.connection;
try
{
if ((txt2.Text == "")| (txt_desc2.Text == ""))
appMessages.unCompleteFields();
else
{
long from = long.Parse(this.txt2.Text);
long to = long.Parse(this.txt3.Text);
if (from <= to)
{
for (long counter = from; counter <= to; counter++)
{
string upd = "update card set LockState=@lockstate,
card_descr=@card_descr where [cardNumber] = N'{0}'";
rwd.command.CommandText = upd;
rwd.command.Parameters.Add(new SqlParameter("@LockState",
SqlDbType.NVarChar)).Value =1;
rwd.command.Parameters.Add(new SqlParameter("@card_descr",
SqlDbType.NVarChar)).Value = txt_desc2.Text;
rwd.connection.Open();
rwd.command.ExecuteScalar();
rwd.connection.Close();
}
appMessages.successfulyUpdated();
}
else
{
appMessages.unsuccessfulyUpdated();
}
this.txt1.Text = "";
this.txt2.Text = "";
}
}
catch (Exception exp) { throw exp; }
}
}
Run Code Online (Sandbox Code Playgroud)
gza*_*axx 19
您在每次循环迭代中添加多次相同的参数.
rwd.command.Parameters.Clear()每次循环迭代后添加:
for (long counter = from; counter <= to; counter++)
{
rwd.command.Parameters.Clear();
string upd = "update card set LockState=@lockstate, card_descr=@card_descr where [cardNumber] = N'{0}'";
rwd.command.CommandText = upd;
rwd.command.Parameters.Add(new SqlParameter("@LockState",
SqlDbType.NVarChar)).Value =1;
rwd.command.Parameters.Add(new SqlParameter("@card_descr",
SqlDbType.NVarChar)).Value = txt_desc2.Text;
rwd.connection.Open();
rwd.command.ExecuteScalar();
rwd.connection.Close();
}
Run Code Online (Sandbox Code Playgroud)
或者在循环之前添加参数:
rwd.command.Parameters.Add(new SqlParameter("@LockState", SqlDbType.NVarChar));
rwd.command.Parameters.Add(new SqlParameter("@card_descr", SqlDbType.NVarChar));
Run Code Online (Sandbox Code Playgroud)
然后循环:
for (long counter = from; counter <= to; counter++)
{
string upd = "update card set LockState=@lockstate,
card_descr=@card_descr where [cardNumber] = N'{0}'";
rwd.command.CommandText = upd;
rwd.command.Parameters["@LockState"].Value =1;
rwd.command.Parameters["@card_descr"].Value = txt_desc2.Text;
rwd.connection.Open();
rwd.command.ExecuteScalar();
rwd.connection.Close();
}
Run Code Online (Sandbox Code Playgroud)
Dam*_*ith 14
因为您在每次迭代中共享命令,所以清除循环开头的参数.
for (long counter = from; counter <= to; counter++)
{
rwd.command.Parameters.Clear();
Run Code Online (Sandbox Code Playgroud)
但我只会通过在循环之前定义循环中的值来设置循环中的值,如下所示
rwd.command.Parameters.Add("@LockState",SqlDbType.NVarChar);
rwd.command.Parameters.Add("@card_descr",SqlDbType.NVarChar);
for (long counter = from; counter <= to; counter++)
{
rwd.command.Parameters["@LockState"].Value = 1;
rwd.command.Parameters["@card_descr"].Value = txt_desc2.Text;
// ...
}
Run Code Online (Sandbox Code Playgroud)
边注:
你有[cardNumber] = N'{0}'"但从未为此设定价值.你最好还使用参数cardNumber.
| 归档时间: |
|
| 查看次数: |
37224 次 |
| 最近记录: |