0

我有这段代码循环遍历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();
}
}
}
4

1 回答 1

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();
          }
     }
}
于 2013-05-25T13:21:28.140 回答