2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0

9.6. 位串函数和运算符 #

本节描述用于检查和操作位串(即 bitbit varying 类型的值)的函数和运算符。(虽然这些表中只提到了 bit 类型,但 bit varying 类型的值可以互换使用。)位串支持 表 9.1 中所示的常用比较运算符,以及 表 9.14 中所示的运算符。

表 9.14. 位串运算符

运算符

描述

示例

bit || bitbit

连接

B'10001' || B'011'10001011

bit & bitbit

按位与(输入必须具有相同的长度)

B'10001' & B'01101'00001

bit | bitbit

按位或(输入必须具有相同的长度)

B'10001' | B'01101'11101

bit # bitbit

按位异或(输入必须具有相同的长度)

B'10001' # B'01101'11100

~ bitbit

按位非

~ B'10001'01110

bit << integerbit

按位左移(字符串长度保持不变)

B'10001' << 301000

bit >> integerbit

按位右移(字符串长度保持不变)

B'10001' >> 200100


一些可用于二进制字符串的函数也可用于位串,如 表 9.15 所示。

表 9.15. 位串函数

函数

描述

示例

bit_count ( bit ) → bigint

返回位串中设置为 1 的位数(也称为“popcount”)。

bit_count(B'10111')4

bit_length ( bit ) → integer

返回位串中的位数。

bit_length(B'10111')5

length ( bit ) → integer

返回位串中的位数。

length(B'10111')5

octet_length ( bit ) → integer

返回位串中的字节数。

octet_length(B'1011111011')2

overlay ( bits bit PLACING newsubstring bit FROM start integer [ FOR count integer ] ) → bit

bits 中从第 start 位开始、长度为 count 位的子串替换为 newsubstring。如果省略 count,则默认为 newsubstring 的长度。

overlay(B'01010101010101010' placing B'11111' from 2 for 3)0111110101010101010

position ( substring bit IN bits bit ) → integer

返回指定 substringbits 中首次出现的位置(从 1 开始计数),如果不存在则返回零。

position(B'010' in B'000001101011')8

substring ( bits bit [ FROM start integer ] [ FOR count integer ] ) → bit

提取 bits 中的子串。如果指定了 start,则从第 start 位开始;如果指定了 count,则提取 count 位。至少需要指定 startcount 中的一个。

substring(B'110010111111' from 3 for 2)00

get_bit ( bits bit, n integer ) → integer

从位串中提取第 n 位;最左边的第一位是第 0 位。

get_bit(B'101010101010101010', 6)1

set_bit ( bits bit, n integer, newvalue integer ) → bit

将位串中的第 n 位设置为 newvalue;最左边的第一位是第 0 位。

set_bit(B'101010101010101010', 6, 0)101010001010101010


此外,还可以将整数值转换为 bit 类型,或从 bit 类型转换回整数。将整数转换为 bit(n) 会复制最右边的 n 位。将整数转换为比整数本身宽度更宽的位串会在左侧进行符号扩展。一些示例

44::bit(10)                    0000101100
44::bit(3)                     100
cast(-44 as bit(12))           111111010100
'1110'::bit(4)::integer        14

请注意,仅转换为 bit 意味着转换为 bit(1),因此只返回整数的最低有效位。

提交更正

如果您在文档中发现任何不正确的内容、与您对特定功能的实际体验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。