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

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

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

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

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

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


当前回答

如果使用BOOLEAN类型,则别名为TINYINT(1)。如果你想使用标准化的SQL并且不介意字段可能包含一个超出范围的值(基本上任何不是0的都将是“true”),这是最好的。

ENUM('False', 'True')将允许您在SQL中使用字符串,MySQL将根据指定ENUM的顺序将字段内部存储为'False'=0和'True'=1的整数。

在MySQL 5+中,您可以使用BIT(1)字段来表示1位数值类型。我不认为这实际上减少了存储空间,但再次允许您将可能的值限制为1或0。

以上所有方法使用的存储空间大致相同,因此最好选择最容易使用的方法。

其他回答

如果使用BOOLEAN类型,则别名为TINYINT(1)。如果你想使用标准化的SQL并且不介意字段可能包含一个超出范围的值(基本上任何不是0的都将是“true”),这是最好的。

ENUM('False', 'True')将允许您在SQL中使用字符串,MySQL将根据指定ENUM的顺序将字段内部存储为'False'=0和'True'=1的整数。

在MySQL 5+中,您可以使用BIT(1)字段来表示1位数值类型。我不认为这实际上减少了存储空间,但再次允许您将可能的值限制为1或0。

以上所有方法使用的存储空间大致相同,因此最好选择最容易使用的方法。

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

我厌倦了试图得到零,null,和“准确地循环PHP, MySql和POST值,所以我只是使用'是'和'No'。

这是完美无缺的工作,不需要特别的处理,不明显,容易做到。

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

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:优化,备份,复制和更多”中有描述。)

你可以使用BOOL, BOOLEAN数据类型来存储布尔值。

这些类型是TINYINT(1)的同义词。

然而,BIT(1)数据类型更适合存储布尔值(true[1]或false[0]),而TINYINT(1)更容易用于输出数据、查询等,并实现MySQL和其他数据库之间的互操作性。你也可以检查这个答案或线程。

MySQL还将BOOL, BOOLEAN数据类型转换为TINYINT(1)。

此外,阅读文档