受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

8.10. 位串类型 #

位串是由 1 和 0 组成的字符串。它们可用于存储或展示位掩码。 SQL 中有两种位类型: bit(n)bit varying(n),其中 n 是正整数。

bit 类型的数据长度必须与 n 完全一致;试图存储更短或更长的位串 都会报错。bit varying 数据则是长度上限为 n 的变长类型,更长的串会被拒绝。 不带长度的 bit 等效于 bit(1), 而不带长度说明的 bit varying 表示长度不受限。

Note

如果显式地将一个位串值转换为 bit(n),它会在右侧被截断 或补零,直到长度恰好为 n 位, 且不会报错。类似地,如果显式地将一个位串值转换为 bit varying(n),而其长度 超过 n 位,则会在右侧被截断。

关于位串常量的语法信息,请参见 Section 4.1.2.5。位逻辑操作符和字符串操作 函数也可用;参见 Section 9.6

Example 8.3. 使用位串类型

CREATE TABLE test (a BIT(3), b BIT VARYING(5));
INSERT INTO test VALUES (B'101', B'00');
INSERT INTO test VALUES (B'10', B'101');

ERROR:  bit string length 2 does not match type bit(3)

INSERT INTO test VALUES (B'10'::bit(3), B'101');
SELECT * FROM test;

  a  |  b
-----+-----
 101 | 00
 100 | 101


一个 bit 串值每 8 位需要 1 个字节,再加上 5 或 8 个字节的额外 开销,具体取决于串的长度。(不过,长值可能会被压缩或移到行外存储, 与 Section 8.3 中对字符串的说明相同。)

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。