SQL模糊查询碰到空值怎么办?
2014-08-27 09:10
330 查看
作者:iamlaosong
SQL查询语句用%来做模糊查询,程序中一般要求用户输入部分信息,根据这个信息进行模糊查询。例如用户输入340104,下面这条语句就是查询昨天客户代码为340104开头的所有邮件信息:
当用户什么都不输入需要查询昨天所有邮件信息时,下面的语句并不能查询到所有信息,这条语句只能查到所有大客户的邮件信息,查不到散户的邮件信息:
这是因为散户的客户代码为空值,下面这条语句可以同时兼顾上面两种情形(假定用0000代表空值):
有限定值:
无限定值:
限定值是0000时结果是所有散户:
除了like,not like、not in 、<>等运算符号也都不包含空值,例如下面语句并不包含客户代码为空值的记录:
要想包含,同样需要将条件改为:nvl(t.sender_cust_code,'0000') <> '34122600200300'
总之,当一个字段为空值时,表达式中无论是等于还是不等于,结果都为假,只有 is null结果为真。
SQL查询语句用%来做模糊查询,程序中一般要求用户输入部分信息,根据这个信息进行模糊查询。例如用户输入340104,下面这条语句就是查询昨天客户代码为340104开头的所有邮件信息:
select * from tb_evt_mail_clct t where t.clct_date = trunc(sysdate - 1) and t.sender_cust_code like '340104%'
当用户什么都不输入需要查询昨天所有邮件信息时,下面的语句并不能查询到所有信息,这条语句只能查到所有大客户的邮件信息,查不到散户的邮件信息:
select * from tb_evt_mail_clct t where t.clct_date = trunc(sysdate - 1) and t.sender_cust_code like '%'
这是因为散户的客户代码为空值,下面这条语句可以同时兼顾上面两种情形(假定用0000代表空值):
有限定值:
select * from tb_evt_mail_clct t where t.clct_date = trunc(sysdate - 1) and nvl(t.sender_cust_code,'0000') like '340104%'
无限定值:
select * from tb_evt_mail_clct t where t.clct_date = trunc(sysdate - 1) and nvl(t.sender_cust_code,'0000') like '%'
限定值是0000时结果是所有散户:
select * from tb_evt_mail_clct t where t.clct_date = trunc(sysdate - 1) and nvl(t.sender_cust_code,'0000') like '0000%'
除了like,not like、not in 、<>等运算符号也都不包含空值,例如下面语句并不包含客户代码为空值的记录:
select * from tb_evt_mail_clct t where t.clct_date = trunc(sysdate - 1) and t.sender_cust_code <> '34122600200300'
要想包含,同样需要将条件改为:nvl(t.sender_cust_code,'0000') <> '34122600200300'
总之,当一个字段为空值时,表达式中无论是等于还是不等于,结果都为假,只有 is null结果为真。
相关文章推荐
- SQL模糊查询碰到空值怎么办?
- SQL模糊查询碰到空值怎么办?
- 预声明中的模糊查询sql语句(PreparedStatement like sql)怎么写
- 模糊查询/空值处理/数据排序oreder by/数据分组group by/SQL语句执行顺序
- PB数据窗口sql语句中like后面怎么跟变量模糊查询
- mybatis中怎么使用like形成动态模糊查询,错误使用CONCAT拼接sql的看过来
- SQL Server之 (二) SQL语句 模糊查询 空值处理 聚合函数
- SQL模糊查询
- ASP下实现多条件模糊查询SQL语句
- sql中生成查询的模糊匹配字符串
- SQL的模糊查询
- 实现多条件模糊查询SQL语句
- 有关SQL模糊查询
- SQL语句实现按关健字模糊查询,并按匹配度排序
- 模糊查询SQL语句
- 麻烦问一下单字段按查询结果精度返回结果,思路怎么做(除sql 的union合并)
- SQL模糊查询
- 有关SQL模糊查询
- SQL模糊查询
- 用SQL语句怎么查询列名?