因为MySQL似乎没有任何“布尔”数据类型,你'滥用'哪种数据类型存储真/假的信息在MySQL?

特别是在编写和读取PHP脚本的上下文中。

随着时间的推移,我使用并看到了几种方法:

Tinyint, varchar字段包含0/1, Varchar字段包含字符串'0'/'1'或'true'/'false' 最后枚举包含“true”/“false”两个选项的字段。

以上这些似乎都不是最佳选择。我倾向于选择tinyint 0/1变体,因为PHP中的自动类型转换相当简单地为我提供布尔值。

那么使用哪种数据类型呢?是否有我忽略的布尔值的类型设计?你认为使用一种或另一种类型有什么优点或缺点吗?


当前回答

在阅读了这里的答案后,我决定使用比特(1),是的,它在空间/时间上更好,但一段时间后我改变了主意,我再也不会使用它了。当使用准备好的语句、库等(php)时,它使我的开发变得非常复杂。

从那以后,我一直使用tinyint(1),似乎还不错。

其他回答

我使用TINYINT(1)在Mysql中存储布尔值。

我不知道这样做是否有什么好处……但如果我没有错,mysql可以存储布尔(BOOL),它存储为tinyint(1)

http://dev.mysql.com/doc/refman/5.0/en/other-vendor-data-types.html

这是一个优雅的解决方案,我非常欣赏,因为它使用零数据字节:

some_flag CHAR(0) DEFAULT NULL

如果要将其设置为true,则设置some_flag = ",如果要将其设置为false,则设置some_flag = NULL。

然后测试是否为真,检查some_flag是否为非空,测试是否为假,检查some_flag是否为空。

(这个方法在Jon Warren Lentz, Baron Schwartz和Arjen Lentz的“高性能MySQL:优化,备份,复制和更多”中有描述。)

参考此链接 Mysql中的布尔数据类型,根据应用程序的使用情况,如果只存储0或1,比特(1)是更好的选择。

因为MySQL(8.0.16)和MariaDB(10.2.1)都实现了CHECK约束,所以我现在使用CHECK约束

bool_val TINYINT CHECK(bool_val IN(0,1))

您将只能存储0,1或NULL,以及可以转换为0或1的值,而不会出现'1',0x00, b'1'或TRUE/FALSE等错误。

如果您不想允许使用空值,请添加NOT NULL选项

bool_val TINYINT NOT NULL CHECK(bool_val IN(0,1))

请注意,如果你使用TINYINT, TINYINT(1)或TINYINT(123),实际上没有什么区别。

如果你想让你的模式向上兼容,你也可以使用BOOL或BOOLEAN

bool_val BOOL CHECK(bool_val IN(TRUE,FALSE))

db < > fiddle演示

如果你有很多布尔字段,Bit只比各种字节选项(tinyint, enum, char(1))更有优势。一个位字段仍然占用一个完整的字节。两个位域适合同一个字节。三、四、五、六、七、八。然后开始填充下一个字节。最终节省的成本是如此之小,还有成千上万的其他优化您应该关注。除非您处理的是大量的数据,否则这几个字节加起来不会太多。如果在PHP中使用bit,则需要对进出的值进行类型转换。