MySQL 如何添加布尔类型字段?
您可以使用tinyint(1)或bool或boolean。所有这些都是同义词。如果您使用bool或boolean数据类型,那么它将内部更改为tinyint(1)。
在PHP中,值0表示false,而值1表示true。除0以外的任何其他数字也为true。
让我们使用一个表来检查bool或boolean的内部表示形式。创建表的查询如下所示。
mysql> create table AddBoolDemo
-> (
-> isToggle bool
-> );
Query OK, 0 rows affected (1.24 sec)
要查看表的DDL,可以使用以下查询。
SHOW CREATE TABLE yourTableName;
现在让我们检查bool的表示形式,它在内部转换为tinyint(1)。现在检查表AddBoolDemo。
mysql> show create table AddBoolDemo\G
以下是输出内容。
*************************** 1. row ***************************
Table: AddBoolDemo
Create Table: CREATE TABLE `addbooldemo` (
`isToggle` tinyint(1) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
1 row in set (0.00 sec)
使用insert命令将true或false或1或0字面值添加到表中。
mysql> insert into AddBoolDemo values(true);
Query OK, 1 row affected (0.19 sec)
mysql> insert into AddBoolDemo values(false);
Query OK, 1 row affected (0.19 sec)
mysql> insert into AddBoolDemo values(1);
Query OK, 1 row affected (0.10 sec)
mysql> insert into AddBoolDemo values(0);
Query OK, 1 row affected (0.18 sec)
使用select语句显示表中的所有记录。查询如下所示。
mysql> select *from AddBoolDemo;
以下是输出内容。
+----------+
| isToggle |
+----------+
| 1 |
| 0 |
| 1 |
| 0 |
+----------+
4 rows in set (0.00 sec)
阅读更多:MySQL 教程