我有2列是名称和价格。 假设数据库表中已经有一些数据将显示在datagridview中。 现在,当用户输入新的数据行时(无论有多少行),并且他们点击保存按钮,所有新行数据将被保存到数据库中。c#sql 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添加的每个数据到数据库,并不断重复。
感谢您的关注。
你能否提供一些示例代码供我参考?或一些链接,谢谢 – 2012-08-11 00:53:45
试试这个http://technico.qnownow.com/how-to-insert-update-delete-rows-in-asp-net-gridview-control/ – 2012-08-13 09:09:07