如何將零或空字串插入定義為 NOT NULL 的 MySQL 列中?
宣告一個列為‘NOT NULL’意味著該列不接受 NULL 值,但零 (0) 和空字串本身就是一個值。因此,如果我們想將零或空字串插入定義為 NOT NULL 的 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) 不是 NULL。這意味著零 (0) 本身就是一個值,因為我們知道 NULL 表示“無值”。
mysql> Select '' IS NULL, '' IS NOT NULL; +------------+----------------+ | '' IS NULL | '' IS NOT NULL | +------------+----------------+ | 0 | 1 | +------------+----------------+ 1 row in set (0.00 sec)
以上結果集顯示空字串 (‘’) 不是 NULL。這意味著空字串 (‘’) 本身就是一個值,因為我們知道 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) 和空字串 (‘’) 插入宣告為 NOT NULL 的列中。
廣告
資料結構
網路
關係資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP