讨论:PB与ORACLE,空字符串与NULL的更新

sjlion 2010-01-28 02:31:05
环境描述:Oracle 10. PB9.0.0.5507

问题描述:
表A,有5列,分别为id,a,b,c,d。id为key_column.所有列的数据类型均为varchar(2).创建一数据窗口,数据源为select * from A. 更新属性为: KEY MODIFICATION = Use Update; WHERE CLAUSE FOR UPDATE/INSERT= Key AND Updateable Columns;所有列均为可更新列。设当前数据窗口控件为dw_test. 执行dw_test.retrieve()后得到表A内容,在dw_test内修改第1行中列a,将其内容清空,执行dw_test.update(),成功,然后commit。紧接着,再修改第1行列b,修改方式随意。修改后,执行dw_test.update(),失败。错误提示为:Row changed between retrieve and update.


原因:
在第二次执行dw_test.update()时,生成的update语句的where条件为 where ....and a = ''....(其他条件省略),因为Oracle是没有空字符串的,所以第一次执行update时,update A set a='' (因为a被清空了) 会把a的值转成null,所以a现在数据库中的值为null. 而在第二次 dw_test.update() where条件中的a='',Oracle却不会认为它和 a is null等价,换句话讲,Oracle不允许a=''这样的语句出现在 where 右边(当然select * from A where a=''不会报错,却永远检索不到结果)。所以第二次PB生成的update语句更新不了任何一行数据,所以会提示行已经发生变化。

处理:
我现在的处理方式是在updatestart事件中,遍历所有修改过的行的列,遇有值为''的,setitem其值为null. 这样,它第一次更新时就生成 update A set a= null0.....,第二次更新时生成的语句就是 update ... where ... and a is null and ....

???:谁有更好的办法?我觉得我的处理方式太笨。求最优解决方式!!!!

悬66分,希望大家都顺,哈:)
...全文
804 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
sjlion 2010-01-28
  • 打赏
  • 举报
回复
哈,empty string is null ,枉我用了六七年PB啊,居然把这个属性忘掉了!!惭愧啊惭愧!多谢仁兄哦。结贴了。妈的,ORACLE啊,SQL SERVER就没这毛病.....哈哈,预祝大家新年快乐吧。
archlwh 2010-01-28
  • 打赏
  • 举报
回复
顶楼上的,这个方法可以。。多谢楼主和楼上大哥啊。。
zb63668331 2010-01-28
  • 打赏
  • 举报
回复 1
我的是PB10.5,刚才我测试一下一个选项 empty string is null 如果勾是 则是 '列 = NULL' 如果不勾则是 ' 列 = '' '
看是否符合你要求
archlwh 2010-01-28
  • 打赏
  • 举报
回复
不好意思啊,没有仔细看,刚开中国网球输了,心情不好。楼主,我按照你那个问题描写的一样做了,但是怎么没有出现保存失败啊!我是oracle 9,pb9.0.3 8836
zb63668331 2010-01-28
  • 打赏
  • 举报
回复
BD,可惜没装Oracle,没法试
sjlion 2010-01-28
  • 打赏
  • 举报
回复
多谢1楼,不过你很明显没仔细看我的问题,他说的那个和我的不一样。我很清楚我这个问题产生的原因,我也现在也有解决方法。只是求一个更优的解法。补充一下,我不可能更改WHERE CLAUSE FOR UPDATE/INSERT 为key,那样根本没办法控制并发。
archlwh 2010-01-28
  • 打赏
  • 举报
回复
http://topic.csdn.net/t/20050513/17/4004957.html 这里就是你说的这个问题

754

社区成员

发帖
与我相关
我的任务
社区描述
PowerBuilder 数据库相关
社区管理员
  • 数据库相关社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧