位串是由 1 和 0 组成的字符串。它们可用于存储或展示位掩码。 SQL 中有两种位类型: bit( 和 n)bit varying(,其中 n)n 是正整数。
bit 类型的数据长度必须与 n 完全一致;试图存储更短或更长的位串 都会报错。bit varying 数据则是长度上限为 n 的变长类型,更长的串会被拒绝。 不带长度的 bit 等效于 bit(1), 而不带长度说明的 bit varying 表示长度不受限。
如果显式地将一个位串值转换为 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 中对字符串的说明相同。)
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。