支持的版本:当前 (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

返回位串中设置的位数(也称为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

返回bits中指定substring的第一个起始索引,如果不存在则返回零。

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

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

如果指定了,则提取从第start位开始的bits的子字符串;如果指定了,则在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),因此只会传递整数的最低有效位。

提交更正

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