P
pclover
Unregistered / Unconfirmed
GUEST, unregistred user!
这是一个常见但容易被忽视的问题,旧贴有问及但没答案,因此提高分数。
相信大家常这样使用Cache模式;
ADOConnection1.BeginTrans;
Try
ADODataSet1.UpdateBatch(arAll);
ADOConnection1.CommitTrans;
Except
ADOConnection1.RollbackTrans;
Raise;
End;
通常,用户会增加或修改多条记录然后保存,但是,当其中一条记录违反
数据库规则,这时会Rollback,然后提示错误,然后用户修改出错的记录,
然后再保存,这时会出现什么情况呢?(提示:除了用户刚修改的记录外,
其它记录的状态都变成了usUnmodified)
同样,把这个BUG推广到多表中:
ADOConnection1.BeginTrans;
Try
ADODataSet1.UpdateBatch(arAll);
ADODataSet2.UpdateBatch(arAll); // <- 假设出错,然后用户再改正
ADOConnection1.CommitTrans;
Except
ADOConnection1.RollbackTrans;
Raise;
End;
同样,DataSet1的修改会被忽略。
在Borland Newsgroup上,有TeamB的高手给出了SavetoFile,LoadFromFile的
解决方案,我觉得不是一个好办法,看看这儿大家有什么解决方法。
看来,BDE的两段提交(ApplyUpdate,CommitUpdate)比ADO好n倍啊。
相信大家常这样使用Cache模式;
ADOConnection1.BeginTrans;
Try
ADODataSet1.UpdateBatch(arAll);
ADOConnection1.CommitTrans;
Except
ADOConnection1.RollbackTrans;
Raise;
End;
通常,用户会增加或修改多条记录然后保存,但是,当其中一条记录违反
数据库规则,这时会Rollback,然后提示错误,然后用户修改出错的记录,
然后再保存,这时会出现什么情况呢?(提示:除了用户刚修改的记录外,
其它记录的状态都变成了usUnmodified)
同样,把这个BUG推广到多表中:
ADOConnection1.BeginTrans;
Try
ADODataSet1.UpdateBatch(arAll);
ADODataSet2.UpdateBatch(arAll); // <- 假设出错,然后用户再改正
ADOConnection1.CommitTrans;
Except
ADOConnection1.RollbackTrans;
Raise;
End;
同样,DataSet1的修改会被忽略。
在Borland Newsgroup上,有TeamB的高手给出了SavetoFile,LoadFromFile的
解决方案,我觉得不是一个好办法,看看这儿大家有什么解决方法。
看来,BDE的两段提交(ApplyUpdate,CommitUpdate)比ADO好n倍啊。