数据库中有一些现有数据,用户将新数据输入datagridview,我想将其添加到数据库中。
而且我真的不知道如何将datagridview中新插入的数据行添加到数据库中。如何仅获取新插入的数据?我被告知我可以使用tempID将它分配给新插入的行,但我不知道如何做到这一点。任何人都可以给我一些链接吗?
这是我现在的代码:
private void button1_Click(object sender, EventArgs e)
{
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-2; 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();
}
答案 0 :(得分:1)
我认为您应该以不同方式处理数据网格插入。看看这个:
当网格能够允许用户在数据绑定时向数据库插入新行时,我认为不允许本地工作然后插入所有新行是最好的方法。该示例是数据库异步调用以释放UI。
我认为你至少应该使用StringBuilder进行查询;更易于管理,我希望你不会真的像那样留下连接字符串。