问题:
设置变量名称为l_somevariable, 当其值为null时,通过null = null 或者 null <> null,都不能查到值,用null is null可以查询得到值
方法1:
故我们可以通过如下语句进行查询
select * from t where (x = l_somevariable or (x is null and l_somevariable is null))
但此时,当值为null时,x上的B*树索引不起作用。
方法2:
我们可以通过建立函数索引的方式实现:
create index t_idx on t(nvl(x, -1));
select * from t where nvl(x, -1) = nvl(l_somevariable, -1)
设置变量名称为l_somevariable, 当其值为null时,通过null = null 或者 null <> null,都不能查到值,用null is null可以查询得到值
方法1:
故我们可以通过如下语句进行查询
select * from t where (x = l_somevariable or (x is null and l_somevariable is null))
但此时,当值为null时,x上的B*树索引不起作用。
方法2:
我们可以通过建立函数索引的方式实现:
create index t_idx on t(nvl(x, -1));
select * from t where nvl(x, -1) = nvl(l_somevariable, -1)
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10712951/viewspace-1244720/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/10712951/viewspace-1244720/