如何通過傳參數控制where的條件?

jxf_13 2003-07-15 09:53:39
我不想用GetSqlselect()及SetSqlSelect()更改SQL中的Where條件來改變DW檢索數據范圍﹐因有時不方便, 在SQLSVR中我使用這種方法, 不輸入則不限制,
strFrNo = trim(sle_frNo.text)
if strFrNo < ' ' then setNull(strFrNo)
strToNo = trim(sle_toNo.text)
if strToNo < ' ' then setNull(strToNo)

在DW中有兩個arguments (astrFrNo string, astrToNo string)
DW的SQL語句為:
select * from gbitem
where (:astrFrNo is null or itemno >= :astrFrNo) and
(:astrToNo is null or itemno <= :astrToNo)
這樣傳入空值參數則不限制.
現在使用ODBC聯結AS400上的DB2數據庫﹐當向DW傳入空值參數時, ODBC則報
錯﹐表示不接收空值NULL的參數。如何在這種情況下通過傳參數控制where的條件達到
SQLSVR相同的效果(不相用SetSqlselect()不方法)?


...全文
75 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
runsoft 2003-07-16
  • 打赏
  • 举报
回复
应该是 null 在 DB2中不识别吧,isnull 试一下。
bapi 2003-07-15
  • 打赏
  • 举报
回复
不知DB2中有没有类似MSSQL中IsNull()的函数,要不写成这样试试:
...
where (ISNULL(:astrFrNo,'')='' or itemno >= ISNULL(:astrFrNo,'')) and
(ISNULL(:astrToNo,'')='' or itemno <= ISNULL(:astrToNo,''))

609

社区成员

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

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