如何遍历datatable中的每一行并在mySQL中插入数据

时间:2013-05-25 13:18:08

标签: c# mysql datatable datarow

我有这个代码循环遍历datagridview中的每一行但我不知道使用数据表时的等效代码是什么。我尝试使用datarow而不是DataGridViewRow,但我不知道如何在每行中获取数据,就像我在此代码中所做的那样。那么我如何获取数据表中每一行的数据?

using (MySqlCommand cmd = new MySqlCommand(query_1, con))
{
foreach (DataGridViewRow dr in dataGridView2.Rows)
{
if (Convert.ToInt32(dr.Cells["quantity"].Value) > 0)
{
cmd.Parameters.AddWithValue("@product", dr.Cells["product_name"].Value);
cmd.Parameters.AddWithValue("@variant", dr.Cells["variant_name"].Value);
cmd.Parameters.AddWithValue("@size", dr.Cells["size"].Value);
cmd.Parameters.Add("@qty", MySqlDbType.Int32, 8).Value = dr.Cells["quantity"].Value;
cmd.Parameters.AddWithValue("@ID", txtboxID.Text);
cmd.ExecuteNonQuery();
cmd.Parameters.Clear();
}
}
}

1 个答案:

答案 0 :(得分:1)

使用这样的语法

dr.Field<string>("product_name");

需要引用System.Data.DataSetExtensions.dll

using (MySqlCommand cmd = new MySqlCommand(query_1, con))
{
    cmd.Parameters.AddWithValue("@product", "");
    cmd.Parameters.AddWithValue("@variant", "");
    cmd.Parameters.AddWithValue("@size", 0);
    cmd.Parameters.Add("@qty", MySqlDbType.Int32, 8).Value = 0:
    cmd.Parameters.AddWithValue("@ID", txtboxID.Text);
    foreach (DataRow dr in yourTable.Rows)
    {
         if (dr.Field<int>("quantity") > 0)
         {
             cmd.Parameters["@product"].Value = dr.Field<string>("product_name");
             cmd.Parameters["@variant"].Value = dr.Field<string>("variant_name");
             cmd.Parameters["@size".Value = dr.Field<int>("size");
             cmd.Parameters["@qty"].Value = dr.Field<int>("quantity");
             cmd.ExecuteNonQuery();
             // no need to clear, reuse the same set of parameters
             //  cmd.Parameters.Clear();
          }
     }
}