当前位置: 代码迷 >> PB >> 讨论:PB与ORACLE,空字符串与NULL的更新,该如何处理
  详细解决方案

讨论:PB与ORACLE,空字符串与NULL的更新,该如何处理

热度:110   发布时间:2016-04-29 09:47:24.0
讨论:PB与ORACLE,空字符串与NULL的更新
环境描述: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分,希望大家都顺,哈:)

------解决方案--------------------
我的是PB10.5,刚才我测试一下一个选项 empty string is null 如果勾是 则是 '列 = NULL' 如果不勾则是 ' 列 = '' '
看是否符合你要求
------解决方案--------------------
顶楼上的,这个方法可以。。多谢楼主和楼上大哥啊。。
  相关解决方案