mysql bit类型_详解 MySQL 中的位类型 ( bit )

使用 MySQL 这么多年,这几天是我第一次知道 MySQL 竟然存在 BIT 这种数据类型。位模式的操作,最大名鼎鼎的应该是 「 布隆过滤器 ( Bloom Filter ) 」。

MySQL 中的位模式字面量一般使用 b'val' 或 0bval 语法,val 是只包含 0 和 1 的二进制值,字符 b 之前有无 0 都无关紧要,但要注意的是 0b 是区分大小写的,0b 不能写为 0B ,但 b 由不限大小写。b001 和 B001 是一个意思。这也是匪夷所思了。

以下这些是合法的位类型字面量

b'01'

B'01'

0b01

而下面这些,则是非法的位类型字面量

b'2' (2 不是合法的二进制数字 )

0B01 (0B 必须是 0b)

默认情况下,位类型的字面量是一个二进制字符串

mysql> SELECT b'1000001', CHARSET(b'1000001');

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

| b'1000001' | CHARSET(b'1000001') |

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

| A | binary |

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

mysql> SELECT 0b1100001, CHARSET(0b1100001);

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

| 0b1100001 | CHARSET(0b1100001) |

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

| a | binary |

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

位类型字面量可以有一个可选的字符集介绍器和 COLLATE 子句,用于指定为使用特定字符集和排序规则的字符串

[_charset_name] b'val' [COLLATE collation_name]

例如

mysql> SELECT _latin1 b'1000001';

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

| _latin1 b'1000001' |

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

| A |

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

1 row in set (0.01 sec)

mysql> SELECT _utf8 0b1000001 COLLATE utf8_danish_ci;

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

| _utf8 0b1000001 COLLATE utf8_danish_ci |

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

| A |

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

1 row in set (0.02 sec)

注意: 示例使用 b'val' 表示法,但 0bval 表示法也是可以的

在数值上下文中,MySQL 会把位类型的数据转换为相应的整型。所以,如果要确保对位类型字面值进行数字处理,请在数字上下文中使用它。

至于如何做到这一点,可以在把这个位类型数据进行 + 0 操作或者使用 CAST (... AS UNSIGNED) 转换器。

例如,默认情况下,分配给用户定义变量的位字面量是二进制字符串。如果要将值指定为数字,请在数字上下文中使用它:

mysql> SET @v1 = b'1100001';

mysql> SET @v2 = b'1100001'+0;

mysql> SET @v3 = CAST(b'1100001' AS UNSIGNED);

mysql> SELECT @v1, @v2, @v3;

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

| @v1 | @v2 | @v3 |

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

| a | 97 | 97 |

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

空位值 b'' 将被计算为零长度二进制字符串。转换为数字则位 0 :

mysql> SELECT CHARSET(b''), LENGTH(b'');

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

| CHARSET(b'') | LENGTH(b'') |

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

| binary | 0 |

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

mysql> SELECT b''+0;

+-------+

| b''+0 |

+-------+

| 0 |

+-------+

位类型的 0b 或 b 语法可以方便的指定要分配给 BIT 列的值

mysql> CREATE TABLE t (b BIT(8));

mysql> INSERT INTO t SET b = b'11111111';

mysql> INSERT INTO t SET b = b'1010';

mysql> INSERT INTO t SET b = b'0101';

在查询时,结果集中的位值将作为二进制值返回,可读性就会差很多,这时候我们可以将它们转换为十进制或者十六进制,我们可以使用转换函数 bin() 或 hex() 两个函数来完成这种转换。转换的时候会忽略高位中的 0

mysql> SELECT b+0, BIN(b), OCT(b), HEX(b) FROM t;

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

| b+0 | BIN(b) | OCT(b) | HEX(b) |

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

| 255 | 11111111 | 377 | FF |

| 10 | 1010 | 12 | A |

| 5 | 101 | 5 | 5 |

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

对于位类型,位操作被视为应当在数字上下文中进行,但在 MySQL 8.0 及更高的版本中,可以直接使用位操作数字或二进制字符串参数

在这种情况下,就至少要位其中一个参数使用 _binary 介绍器,将位类型的数据指定为二进制字符串上下文

mysql> SET @v1 = b'000010101' | b'000101010';

mysql> SET @v2 = _binary b'000010101' | _binary b'000101010';

mysql> SELECT HEX(@v1), HEX(@v2);

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

| HEX(@v1) | HEX(@v2) |

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

| 3F | 003F |

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

在上面这个范例中,两个位操作的显示结果类似,但没有 _binary 的结果是 BIGINT 值,而 _binary 的结果是二进制字符串。由于结果类型不同,显示的值不同:数字结果不显示高位 0

318ea5a4889e17152039a224ce0ac63c.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值