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