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

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条回答 默认 最新

  • 专家-郭老师 Java领域新星创作者 2019-06-19 10:11
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题