将数据从datagridview插入数据库

时间:2012-08-13 03:29:54

标签: c# sql database datagridview newrow

数据库中有一些现有数据,用户将新数据输入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();
}

1 个答案:

答案 0 :(得分:1)

我认为您应该以不同方式处理数据网格插入。看看这个:

http://www.codeguru.com/csharp/.net/net_data/datagrid/article.php/c13041/Add-Edit-and-Delete-in-DataGridView.htm

当网格能够允许用户在数据绑定时向数据库插入新行时,我认为不允许本地工作然后插入所有新行是最好的方法。该示例是数据库异步调用以释放UI。

我认为你至少应该使用StringBuilder进行查询;更易于管理,我希望你不会真的像那样留下连接字符串。