Oracle / PL SQL / SQL null比较where子句

前端之家收集整理的这篇文章主要介绍了Oracle / PL SQL / SQL null比较where子句前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
关于交易的一个问题将在查询中为空值.

例如,我具有以下字段和值的下表

  1. TABLEX
  2. Column1
  3. 1
  4. 2
  5. 3
  6. 4
  7. 5
  8. ---------
  9. Column2
  10. null
  11. A
  12. B
  13. C
  14. null

我在特定的过程中传递一个变量Y.在这个过程中是一个这样的光标

  1. CURSOR c_results IS
  2. SELECT * FROM TABLEX where column2 = variableY

现在问题是variableY可以是null,A,B或C
如果variableY为null,我想选择所有记录,其中column2为null,否则where2为A,B或C.

我不能做上面的游标/查询,因为如果variableY为空,它将无法工作,因为比较应该是

  1. CURSOR c_results IS
  2. SELECT * FROM TABLEX where column2 IS NULL

我应该使用哪个游标/查询将会包含null或字符串变量.

对不起,如果我的问题有点混乱我不是很善于解释事情.提前致谢.

根据该参数的内容生成不同的sql,或者像这样改变你的sql
  1. WHERE (column2 = variableY) OR (variableY IS NULL AND column2 IS NULL)

猜你在找的Oracle相关文章