如何將零或空字串插入一個被定義為非空值的 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) 和空字串(“”)插入宣告為非空值的列。

更新日期:22-6-2020

1K+ 瀏覽量

開啟您的 職業生涯

透過完成課程來獲得認證

開始學習
廣告
© . All rights reserved.