说起来头头是道
2019-06-19 10:01
采纳率: 25%
浏览 525

C#在窗体修改数据后需要同步到数据库,利用for循环按行同步速度很慢,请问有什么好办法

代码如下:
mycon.Open();
for (int i = 0; i < dgv.Rows.Count; i++)
{
string mystr1 = "数量=" + "'" + dgv.Rows[i].Cells[1].Value.ToString() + "'";
string mystr2 = dgv.Rows[i].Cells["序号"].Value.ToString();
string updateSql = "update 数量 set " + mystr1 + " where 序号=" + mystr2;
SqlCommand mycom = new SqlCommand(updateSql, mycon);
mycom.ExecuteNonQuery();
}

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • 第一:数据库字段不要用中文。
    第二:你这个循环是循环控件里所有数据,也就是没有修改的地方你也修改了,虽然你看不到变化。如果数据量大,当然不适合用
    第三:给你的建议是:双击行数据,弹出窗口,然后读取这行的数据,然后在这个窗口操作数据。如果不想要这种,就需要将已修改的数据记录(不推荐)。

    打赏 评论
  • chinarealone 2019-06-19 11:21

    利用SqlBulkCopy 进行批量提交

    打赏 评论
  • 茂大叔 2019-06-20 04:21

    50行数据居然要半分钟?如果不是网速慢就是电脑该升级了。

    打赏 评论
  • churuxu 2019-06-20 08:28

    数据库批量写可以用事务, 先BeginTransaction,再进行多次写,再Commit,相当于多次的改动一次性提交。至于代码怎么写,网上查一下API手册或者示例。

    打赏 评论
  • XiaoGuaiSs 2019-06-26 17:32

    建议改一行保存一行,不要遍历所有行。

    打赏 评论

相关推荐 更多相似问题