我正在使用DataAdapter,并且我很好地更新了我的数据,没有任何问题,但是当我使用UpdateBatchSize属性时,我得到了一个异常:“并发冲突:批处理命令影响了预期的2条记录中的0条。”
以下代码是我的DAL的一部分
myAdapter.InsertCommand = InsertCmd();
myAdapter.InsertCommand.UpdatedRowSource = System.Data.UpdateRowSource.None;
myAdapter.DeleteCommand = DeleteCmd();
myAdapter.DeleteCommand.UpdatedRowSource = System.Data.UpdateRowSource.None;
myAdapter.UpdateCommand = UpdateCmd();
myAdapter.UpdateCommand.UpdatedRowSource = System.Data.UpdateRowSource.None;
myAdapter.SelectCommand.Connection = myConnection.conn;
myAdapter.InsertCommand.Connection = myConnection.conn;
myAdapter.UpdateCommand.Connection = myConnection.conn;
myAdapter.DeleteCommand.Connection = myConnection.conn;
myAdapter.AcceptChangesDuringUpdate = false;
myAdapter.UpdateBatchSize = 2;
try
{
myAdapter.Update(dt.GetChanges());
}
catch
{
throw;
}发布于 2014-05-01 19:58:26
我搜索后得到的是,你不能使用适配器UpdateBatchSize属性与你的SQL命令提供的优化并发,命令将失败,因为时间戳列的大小或每个列的并发性检查,所以SQL命令将非常大,所以你不能得到所有的东西。
如果想要使用UpdateBatchSize来最小化服务器传输,就必须在use命令或SqlAdapter中提供的并发选项中去掉时间戳列检查
https://stackoverflow.com/questions/23206592
复制相似问题