T
tanafenga
Unregistered / Unconfirmed
GUEST, unregistred user!
处于偷懒,写数据编辑界面直接用dbgrid采用mysql数据库,在delphi7下用adoquery访问数据表发现在特殊的情况下总是有"无法为更新定位行,一些值可能已经在最后一次读取后已更改"这个问题在网上有很多说法,可是描述都与我发现的问题不一样,有环境的大家可以简单程序试一下。数据表:有 fd1,fd2,fd3 字段,数据表中有数据若干dephi程序,一个from,adoquery,datasource,dbgrid ,关联好运行点任何一行数据(假如 fd1=10 fd2='abc' fd3=1)第一步:编辑 fd1,如改称 11第二步:光标移动到 fd2 ,(不要移动行)第三步:光标移动到 fd1,并将fd1改回原来的值 10第四步:移动行(实际就是保存数据),这时候就提示错误了此程序如链接的是oracle数据库,一点问题没有,用mysql总有这个BUG起初以为是mysql server 或陈列client 版本问题,换了也无济于事感觉还是在数据库的缓存机制上有点问题不过可能可以通过修改 dbgrid的代码似乎也可以避开这个问题,但是水平有限不知道哪位有解决的办法,这里跪拜了