如何将零或空字符串插入一个被定义为非空值的 MySQL 列?
将列声明为“非空值”意味着此列不接受空值,但零 (0) 和空字符串本身就是值。因此,如果我们想将零或空字符串插入定义为非空值的 MySQL 列,则不会有任何问题。对 0 和空字符串与 NULL 的以下比较将使其一目了然 −
mysql> Select 0 IS NULL, 0 IS NOT NULL; +-----------+---------------+ | 0 IS NULL | 0 IS NOT NULL | +-----------+---------------+ | 0 | 1 | +-----------+---------------+ 1 row in set (0.00 sec)
上述结果集显示,零 (0) 不为空。这意味着零 (0) 本身是一个值,因为我们知道 NULL 表示没有值。
mysql> Select '' IS NULL, '' IS NOT NULL; +------------+----------------+ | '' IS NULL | '' IS NOT NULL | +------------+----------------+ | 0 | 1 | +------------+----------------+ 1 row in set (0.00 sec)
上述结果集显示,空字符串(“”)不为空。这意味着空字符串(“”)本身是一个值,因为我们知道 NULL 表示没有值。
示例
mysql> create table test(id int NOT NULL, Name Varchar(10));
Query OK, 0 rows affected (0.19 sec)
mysql> Insert into test6(id, name) values('1', 'Gaurav'),('0','Rahul'),('','Aarav');
Query OK, 3 rows affected, 1 warning (0.08 sec)
Records: 3 Duplicates: 0 Warnings: 1
Warning (Code 1366): Incorrect integer value: '' for column 'id' at row 3
mysql> Select * from test;
+----+--------+
| id | Name |
+----+--------+
| 1 | Gaurav |
| 0 | Rahul |
| 0 | Aarav |
+----+--------+
3 rows in set (0.00 sec)从上述结果集可以看出,我们可以将零 (0) 和空字符串(“”)插入声明为非空值的列。
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP