mysql bool_如何将BOOL值插入MySQL数据库

TRUE和FALSE是关键字,不应该被引用为字符串:

INSERT INTO first VALUES (NULL, 'G22', TRUE);

INSERT INTO first VALUES (NULL, 'G23', FALSE);

通过将它们引用为字符串,MySQL将会将它们转换为整数等价物(因为布尔确实只是MySQL中的一个字节的INT),对于任何非数字字符串,它将转换为零。因此,您的表中的值都为0。

非数字字符串转换为零:

mysql> SELECT CAST('TRUE' AS SIGNED), CAST('FALSE' AS SIGNED), CAST('12345' AS SIGNED);

+------------------------+-------------------------+-------------------------+

| CAST('TRUE' AS SIGNED) | CAST('FALSE' AS SIGNED) | CAST('12345' AS SIGNED) |

+------------------------+-------------------------+-------------------------+

| 0 | 0 | 12345 |

+------------------------+-------------------------+-------------------------+

但关键字返回相应的INT表示形式:

mysql> SELECT TRUE, FALSE;

+------+-------+

| TRUE | FALSE |

+------+-------+

| 1 | 0 |

+------+-------+

还要注意,我已经用单引号将双引号替换为更标准的SQL字符串外壳。最后,我已经将id的空字符串替换为NULL。空字符串可能会发出警告。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值