我需要一种方法来更新datagridview中的单元格并使用查询将其保存到数据库中,但我得到了这个例外:
变量名称' @ startdate'已经宣布。变量 名称必须是查询批处理或存储过程唯一的
这是我的代码:
private void toolStripLabel1_Click(object sender, EventArgs e)
{
try
{
conn.Open();
string query2 = "UPDATE [Semester] SET [Start_Date]=@startdate, " +
" [End_Date]=@enddate WHERE [Sem_Num]=@sem";
cmd = new SqlCommand(query2, conn);
if (dataGridView1.Rows.Count > 0)
{
for (int i = 0; i < dataGridView1.Rows.Count; i++)
{
cmd.Parameters.AddWithValue("@startdate",
dataGridView1.Rows[i].Cells[1].Value.ToString());
cmd.Parameters.AddWithValue("@enddate",
dataGridView1.Rows[i].Cells[2].Value.ToString());
cmd.Parameters.AddWithValue("@sem",
Convert.ToInt32(dataGridView1.Rows[i].Cells[0].Value));
this.dataGridView1.EndEdit();
cmd.ExecuteNonQuery();
}
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
conn.Close();
}
}
答案 0 :(得分:2)
清除每次迭代中的参数:
for (int i = 0; i < dataGridView1.Rows.Count; i++)
{
cmd.Parameters.Clear();
cmd.Parameters.AddWithValue("@startdate", dataGridView1.Rows[i].Cells[1].Value.ToString());
cmd.Parameters.AddWithValue("@enddate", dataGridView1.Rows[i].Cells[2].Value.ToString());
cmd.Parameters.AddWithValue("@sem", Convert.ToInt32(dataGridView1.Rows[i].Cells[0].Value));
this.dataGridView1.EndEdit();
cmd.ExecuteNonQuery();
}
或者在循环外定义参数并在其中设置值:
var startParam = cmd.Parameters.Add("@startdate", SqlDbType.DateTime2);
var endParam = cmd.Parameters.Add("@enddate", SqlDbType.DateTime2);
var semParam = cmd.Parameters.Add("@sem", SqlDbType.Int);
for (int i = 0; i < dataGridView1.Rows.Count; i++)
{
startParam.Value = Convert.ToDateTime(dataGridView1.Rows[i].Cells[1].Value);
endParam.Value = Convert.ToDateTime(dataGridView1.Rows[i].Cells[2].Value);
semParam.Value = Convert.ToInt32(dataGridView1.Rows[i].Cells[0].Value);
cmd.ExecuteNonQuery();
}
答案 1 :(得分:0)
每次循环运行时,您都会向同一命令添加新参数。
您需要清除参数或创建新命令。