位串是 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
位,它将在右边被截断。
请参阅 第 4.1.2.5 节,了解有关位串常量语法的详细信息。位逻辑运算符和字符串操作函数可用;请参阅 第 9.6 节.
示例 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
一个位串值需要 1 字节来存储每组 8 位,加上 5 或 8 字节的开销,具体取决于字符串的长度(但长值可能会被压缩或移出,如 第 8.3 节 中关于字符字符串的解释)。
如果您在文档中看到任何不正确的内容,不符合您对特定功能的体验,或需要进一步说明,请使用 此表格 报告文档问题。