ClientDataSet应用更新时,服务端控件先要检索该记录:select * from 表名 where 字段1='更新前内容' and 字段2='更新前内容' and 字段3='更新前内容' and …… 所有字段都作为条件。
该错误出现的情况有:
1、该记录在提交更新时被他人修改过
2、字段中有长日期类型
解决方法:
不用ClientDataSet更新,通过SQL语句更新或者设置服务端的控件的字段属性,把主键字段的ProviderFlags的pfinKey属性设为true,这样ClientDataSet更新时服务端检索记录时的条件仅包含该字段而不是所有字段
当然,这样的话如果在提交之前该记录被他人修改过(不改主键字段)的话,你仍可更新该记录,而不会有你看到的错误提示。