gpt4 book ai didi

c# - 如何循环遍历数据表中的每一行并在mySQL中插入数据

转载 作者:行者123 更新时间:2023-11-29 13:50:27 24 4
gpt4 key购买 nike

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

最佳答案

使用这样的语法

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();
}
}
}

关于c# - 如何循环遍历数据表中的每一行并在mySQL中插入数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16749946/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com