列を「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 ではないことを示しています。これは、NULL が値がないことを意味することがわかっているため、ゼロ (0) 自体が値であることを意味します。
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)
上記の結果セットからわかるように、NOT NULL と宣言されたステートメントにゼロ (0) または空の文字列 ("") を挿入できます。コラムで。
以上がNOT NULL として定義された MySQL カラムにゼロまたは空の文字列を挿入するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。