代码如下:
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();
}
第一:数据库字段不要用中文。
第二:你这个循环是循环控件里所有数据,也就是没有修改的地方你也修改了,虽然你看不到变化。如果数据量大,当然不适合用
第三:给你的建议是:双击行数据,弹出窗口,然后读取这行的数据,然后在这个窗口操作数据。如果不想要这种,就需要将已修改的数据记录(不推荐)。
利用SqlBulkCopy 进行批量提交
50行数据居然要半分钟?如果不是网速慢就是电脑该升级了。
数据库批量写可以用事务, 先BeginTransaction,再进行多次写,再Commit,相当于多次的改动一次性提交。至于代码怎么写,网上查一下API手册或者示例。
建议改一行保存一行,不要遍历所有行。