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

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
    关注

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

    评论

报告相同问题?