mysql中的null和空值的区别(解决mysql使用not in 包含null值的问题)
mysql中的null和空值的区别
解决mysql使用not in 包含null值的问题注意!!!
|
select * from user where uid not in (a,b,c, null ); |
这个sql不回返回任何结果。要避免not in的list中出现null的情况。
另外:
–如果null参与算术运算,则该算术表达式的值为null。(例如:+,-,*,/ 加减乘除)
–如果null参与比较运算,则结果可视为false。(例如:>=,<=,<> 大于,小于,不等于)
–如果null参与聚集运算,则聚集函数都置为null(使用isnull(字段,0)等方式可以避免这种情况)。除count(*), count(1), count(0)等之外(count(字段) 字段为null的行不参与计数)。
--如果在not in子查询中有null值的时候,则不会返回数据。
补充:MySQL in,not in,exists,not exists与null的恩恩怨怨
null这个东西在数据里算是个奇葩,在比较中也比较特殊,下面记录总结一下在in,not in,exists,not exists中null对判断结果的影响。
做一些描述声明,在比较符左边的我们称为左比较符,在比较符右边的我们称为右比较符,例如1 in (1,2),那么in左边的1是左比较符,in右边的(1,2)是右比较符。
1.in
1.1当左比较符是null,任何情况下都返回null。
|
mysql> select null in (1,2); + ---------------+ | null in (1,2) | + ---------------+ | NULL | + ---------------+ 1 row in set (0.00 sec) mysql> select null in (1,2, null ); + --------------------+ | null in (1,2, null ) | + --------------------+ | NULL | + --------------------+ 1 row in set (0.00 sec) |
1.2当右比较符包含null,只当左比较符不为null,且右比较符包含左比较符时,返回1,其他情况均返回null。
|
mysql> select null in (1,2, null ); + --------------------+ | null in (1,2, null ) | + --------------------+ | NULL | + --------------------+ 1 row in set (0.00 sec) mysql> select 3 in (1,2, null ); + -----------------+ | 3 in (1,2, null ) | + -----------------+ | NULL | + -----------------+ 1 row in set (0.00 sec) mysql> select 1 in (1,2, null ); + -----------------+ | 1 in (1,2, null ) | + -----------------+ | 1 | + -----------------+ 1 row in set (0.00 sec) |
2.not in
2.1当左比较符为null,任何情况都返回null。
|
mysql> select null not in (1,2, null ); + ------------------------+ | null not in (1,2, null ) | + ------------------------+ | NULL | + ------------------------+ 1 row in set (0.00 sec) mysql> select null not in (1,2); + -------------------+ | null not in (1,2) | + -------------------+ | NULL | + -------------------+ 1 row in set (0.00 sec) |
2.2当右比较符包含null,当右比较符包含左比较符时返回0,其他情况均返回null。
|
mysql> select 1 not in (1,2, null ); + ---------------------+ | 1 not in (1,2, null ) | + ---------------------+ | 0 | + ---------------------+ 1 row in set (0.00 sec) mysql> select 1 not in (2,3, null ); + ---------------------+ | 1 not in (2,3, null ) | + ---------------------+ | NULL | + ---------------------+ 1 row in set (0.00 sec) |
3.exists
exists子查询返回null时判断为真。
|
mysql> select exists ( select null ); + ----------------------+ | exists ( select null ) | + ----------------------+ | 1 | + ----------------------+ 1 row in set (0.00 sec) |
4.not exists
not exists子查询返回null时判断为假。
|
mysql> select not exists ( select null ); + --------------------------+ | not exists ( select null ) | + --------------------------+ | 0 | + --------------------------+ 1 row in set (0.00 sec) |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/weixin_39724194/article/details/105978548
- mysql中默认排序教程(基于mysql 默认排序规则的坑)
- mysql中如何设置多个主键(Mysql 增加主键或者修改主键的sql语句操作)
- MySQL中interactive_timeout和wait_timeout
- docker创建mysql环境(docker上部署MySQL的示例)
- mysql数据库触发器(MySQL中使用游标触发器的方法)
- mysql将字符串转换成整数(MYSQL字符串强转的方法示例)
- mysql执行计划详细解读(详解MySQL的Seconds_Behind_Master)
- mysql的主从复制怎么做(MySQL主从复制原理以及需要注意的地方)
- navicat连接报错10038(解决Navicat for Mysql连接报错1251的问题连接失败)
- mysql 查询语法常见问题(MySQL 异常有这一篇就够了!)
- mysql的四种关系运算(详解MySQL拼接函数CONCAT的使用心得)
- mysql主从复制原理详解(详解MySQL kill 指令的执行原理)
- mysql有什么索引(MySQL 普通索引和唯一索引的区别详解)
- mysql为什么用decimal类型(MySQL decimal unsigned更新负数转化为0)
- mysql详细笔记(MySQL的内存表的基础学习教程)
- mysql 分片键规则(MySql8 WITH RECURSIVE递归查询父子集的方法)
- 赏读 八月再见,九月你好(赏读八月再见九月你好)
- 散文 八月再见,九月,我在风中等你(散文八月再见九月)
- 8月再见 9月你好(8月再见)
- 魔兽世界 设计师爆料,原始版本并无PVP,跨阵营属于返璞归真(魔兽世界设计师爆料)
- 吐槽完《弧光大作战》之后,我们和设计师聊了聊魔兽首款手游的立项初衷和未来(吐槽完弧光大作战之后)
- 魔兽争霸3自定义战役少年杰雷 2(魔兽争霸3自定义战役少年杰雷)
热门推荐
- sql server2008自动备份数据(SQL Server数据库定时自动备份)
- laravel测试重连数据库(Laravel关系模型指定条件查询方法)
- dede栏目seo怎么设置(DedeCMS 标题seo优化 给列表页加上第x页)
- html锚点定位
- python合并多个excel可以刷新吗(python 实现读取一个excel多个sheet表并合并的方法)
- 怎么把数据库备份到阿里(阿里云数据库备份DBS与自建备份系统有什么优势?)
- mysql怎么设置某个字段默认值(MySQL表字段时间设置默认值)
- docker快速配置redis集群(基于docker搭建redis集群的方法)
- 云服务器是不是云主机(云主机和服务器的区别在哪里)
- docker容器端口和内部进程(Docker动态给容器Container暴露端口操作)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9