说起来头头是道 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 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器