域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

MySQL实现BOOLEAN

茴香豆有多少种写法?这是上学时,鲁迅借着孔乙己的手,告诉了我们答案。本章我们将讨论在 MySQL 实现 bool 有多少种方法。

MySQL 哪怕到了 8.x 版本,也没有内置 bool 类型(PostgreSQL 一开始就提供了boolean类型),在日常开发中,如何表达 bool 值呢?

TINYINT

使用 TINYINT 表示 bool 值,在 MySQL 界应该是应用最广泛的方法:

CREATE TABLE tmp_bool1(
    is_del TINYINT NOT NULL DEFAULT 0 COMMENT '0:FALSE;1:TRUE'
);

当然,除了 TINYINT,你可以用包括 INTBIGINT 甚至 DECIMAL 在内的任何整数类型来表达——只要你不心疼你的系统资源,因为它的思想很简单,像 C 语言那样:

  • 0FALSE
  • 1TRUE(实际在 C 语言中是非0TURE

其实,在 MySQL 内部也是使用 01 判断是否成立:

SELECT 1 > 0;
/*
+-------+
| 1 > 0 |
+-------+
|     1 |
+-------+
*/

TINYINT 的存储空间是 1 字节

当然,除了“不人道”的 01,使用 CHAR(1)可以提供更为“人道”的实现——当然,你也可以用CHAR(1024)VARCHAR(1024),甚至 TEXT 来表示,只要你不心疼资源:

CREATE TABLE tmp_bool2(
    is_del CHAR(1) NOT NULL DEFAULT 'F' COMMENT 'F:FALSE;T:TRUE'
);

和使用整数表示相比,至少 CHAR(1) 不再是一眼瞎的 01 了,而是更具词面意义的字母。其实,你完全可以改成汉字:

CREATE TABLE tmp_bool2(
    is_del CHAR(1) NOT NULL DEFAULT '假' COMMENT '假:FALSE;真:TRUE'
);

CHAR(1) 的存储空间是 1 字节

CHAR(1) 的存储空间是 1 字节

无论是上述的 TINYINT 还是 CHAR(1),它们都存在一个风险:

  • 对于 TINYINT:如果输入的数据不是 01 呢,比如:100,或者 -1——是的,你可以向 C 语言那样,非 0TRUE
  • 对于 CHAR(1):如果输入的数据不是 F/T假/真呢,比如:A——是的,你可以向 C 语言学习,比如非 F 或非 TRUE

这些都是业务逻辑上控制的,你知道的,在 Rust (或其它像 Go 这种现代语言)中,bool 只能是 false/true,不可能出现第 3 个值。其实,MySQL 的Enum是可以达到这个效果的:

CREATE TABLE tmp_bool3(
    is_del ENUM('FALSE','TRUE') NOT NULL DEFAULT 'FALSE'
);

当你试图插入 FALSE/TRUE (不区分大小写,可以用对应的数字替代)之外的数据时,MySQL 将报错。不错,至少实现了编程语言中的 bool 所要的特性。而且,因为支持使用对应的数字(按 ENUM(元素列表)的定义顺序),也符合 C 语言的特性和 MySQL 的判断成功与否的默认行为。

注意,ENUM 的存储空间不是固定的:

  • 当 ENUM 类型包含 1 ~ 255 个成员时,需要 1 个字节的存储空间;

  • 当 ENUM 类型包含 256 ~ 65535 个成员时,需要 2 个字节的存储空间。

  • ENUM 类型的成员个数的上限为 65535 个。

当 ENUM 类型包含 1 ~ 255 个成员时,需要 1 个字节的存储空间;

当 ENUM 类型包含 256 ~ 65535 个成员时,需要 2 个字节的存储空间。

ENUM 类型的成员个数的上限为 65535 个。

本例中,ENUM('FALSE','TRUE') 的存储空间是 1 字节

本例中,ENUM('FALSE','TRUE') 的存储空间是 1 字节

如果你学计算机基础的时候不是太躺平,应该知道,字节(byte)位(bit) 的关系。

MySQL 提供了 BIT 数据类型:

CREATE TABLE tmp_bool4(
    is_del BIT(1) NOT NULL DEFAULT 0 COMMENT '0:False;1:True'
);

对于 bool 来说,1 bit 已经足矣,它能存储 01 两个状态。

要查看完整内容,请先登录