我有 2 列名称和价格。假设数据库表中已经有一些数据将显示在 datagridview 中。现在,当用户输入新的数据行(无论有多少行),并单击“保存”按钮时,所有新的数据行都将保存到数据库中。
问题是,我如何只捕获新的数据行?或者我如何检查名称是否存在,检查价格是否相同,然后不要插入,如果不同的价格,然后更新价格。
这是我的代码:
con = new System.Data.SqlClient.SqlConnection();
con.ConnectionString = "Data Source=tcp:SHEN-PC,49172\\SQLEXPRESS;Initial Catalog=LSEStock;Integrated Security=True";
con.Open();
SqlDataAdapter da = new SqlDataAdapter();
for (int i = 0; i<dataGridView1.Rows.Count; i++ )
{
String insertData = "INSERT INTO CostList(SupplierName, CostPrice, PartsID) VALUES (@SupplierName, @CostPrice, @PartsID)" ;
SqlCommand cmd = new SqlCommand(insertData, con);
cmd.Parameters.AddWithValue("@SupplierName", dataGridView1.Rows[i].Cells[0].Value);
cmd.Parameters.AddWithValue("@CostPrice", dataGridView1.Rows[i].Cells[1].Value);
cmd.Parameters.AddWithValue("@PartsID", textBox1.Text);
da.InsertCommand = cmd;
cmd.ExecuteNonQuery();
}
con.Close();
编辑:上面的代码会将datagridview中的每个数据添加到数据库中并继续复制。
感谢您的关注。