MySQLで、booleanデフォルト値がである列を持つテーブルを作成したいと思いますfalse。しかし、デフォルトとしてNULLを受け入れています...
MySQLで、booleanデフォルト値がである列を持つテーブルを作成したいと思いますfalse。しかし、デフォルトとしてNULLを受け入れています...
回答:
デフォルトとして(0falseを意味する)または1(trueを意味する)を指定する必要があります。次に例を示します。
create table mytable (
mybool boolean not null default 0
);
FYI:はのbooleanエイリアスですtinyint(1)。
ここに証明があります:
mysql> create table mytable (
-> mybool boolean not null default 0
-> );
Query OK, 0 rows affected (0.35 sec)
mysql> insert into mytable () values ();
Query OK, 1 row affected (0.00 sec)
mysql> select * from mytable;
+--------+
| mybool |
+--------+
| 0 |
+--------+
1 row in set (0.00 sec)
参考:私のテストは次のバージョンのMySQLで行われました:
mysql> select version();
+----------------+
| version() |
+----------------+
| 5.0.18-max-log |
+----------------+
1 row in set (0.00 sec)