mysql中NULL值

mysql中NULL值表示"没有值",它跟空字符串""是不同的

例如,执行下面两个插入记录的语句:

复制代码
insert into test_table (description) values (null);
insert into test_table (description) values ('');

执行以后,查看表的值,下面第2和第3行是执行前面两条语句生成的:

可以看到,两条插入语句都在表中description列插入了值,但是第1条语句插入的是NULL,第2条语句插入的是空字符串。

有时候可能会有误解:认为一个列定义为NOT NULL,就不能插入空字符串。

其实,一个列定义为NOT NULL,是可以插入空字符串的,因为空字符串是NOT NULL。

下面语句测试空字符串('')和NULL:

要测试NULL,用 IS NULL和IS NOT NULL操作符

例如:

不能使用数学比较符号来测试NULL

不能使用数学比较符号,例如>、<、或者<>来测试NULL。因为,任何的数学比较符号和NULL相比的结果都是NULL,因此从这个比较中,得不到任何有意义的结果。

例如:

在MySQL,0或者NULL代表false,其它值代表true

在MySQL,0或者NULL代表false,其它值代表true。

相关推荐
q***985236 分钟前
基于人脸识别和 MySQL 的考勤管理系统实现
数据库·mysql
l1t1 小时前
用SQL求解advent of code 2024年23题
数据库·sql·算法
办公解码器2 小时前
Excel工作表打开一次后自动销毁文件,回收站中都找不到
数据库·excel
爬山算法3 小时前
Redis(127)Redis的内部数据结构是什么?
数据结构·数据库·redis
百***25613 小时前
MySQL 实验1:Windows 环境下 MySQL5.5 安装与配置
windows·mysql·adb
转转技术团队3 小时前
分页查询的稳定性陷阱与根治方案
后端·mysql·elasticsearch
应用市场3 小时前
Qt QTreeView深度解析:从原理到实战应用
开发语言·数据库·qt
q***96583 小时前
Spring Data JDBC 详解
java·数据库·spring
Hello,C++!3 小时前
linux下libcurl的https简单例子
linux·数据库·https
q***82914 小时前
图文详述:MySQL的下载、安装、配置、使用
android·mysql·adb