本节描述那些检查和操作二进制字符串的函数和操作符,这是类型bytea的值。 其中许多函数在用途和语法上都与上一节中描述的文本字符串函数等效。
SQL定义了一些使用关键字而不是逗号来分割参数的串函数。详情请见表 9.11。PostgreSQL也提供了这些函数使用常规函数调用语法的版本(参阅 表 9.12)。
表 9.11. SQL二进制串函数和操作符
函数/操作符 描述 例子 |
|---|
bytea||bytea→ bytea
连接两个二进制字符串。 '\x123456'::bytea || '\x789a00bcde'::bytea→ \x123456789a00bcde
|
bit_length( bytea) → integer
返回二进制字符串中的位数 (8 倍于 octet_length). bit_length('\x123456'::bytea)→ 24
|
octet_length( bytea) → integer
返回二进制字符串中的字节数。 octet_length('\x123456'::bytea)→ 3
|
overlay( bytesbyteaPLACINGnewsubstringbyteaFROMstartinteger[ FORcountinteger] ) → bytea
将bytes的子字符串替换为newsubstring,该子字符串从start字节开始,并以count字节扩展。 如果忽略了count,则默认为 newsubstring的长度。 overlay('\x1234567890'::bytea placing '\002\003'::bytea from 2 for 3)→ \x12020390
|
position( substringbyteaINbytesbytea) → integer
返回指定的substring在bytes内的起始索引,如果不存在,则为零。 position('\x5678'::bytea in '\x1234567890'::bytea)→ 3
|
substring( bytesbytea[ FROMstartinteger] [ FORcountinteger] ) → bytea
提取bytes从start字节开始的子字符串,如果指定了,并且在count字节之后停止,如果指定了的话。 至少提供start和count中的一个。 substring('\x1234567890'::bytea from 3 for 2)→ \x5678
|
trim( [ BOTH] bytesremovedbyteaFROMbytesbytea) → bytea
从bytes的开始和结束处删除bytesremoved中只包含字节的最长字符串。 trim('\x9012'::bytea from '\x1234567890'::bytea)→ \x345678
|
trim( [ BOTH] [ FROM] bytesbytea, bytesremovedbytea) → bytea
这是trim()的非标准语法。 trim(both from '\x1234567890'::bytea, '\x9012'::bytea)→ \x345678
|
还有一些二进制串处理函数可以使用,在表 9.12列出。 其中有一些是在内部使用,用于实现表 9.11列出的 SQL 标准串函数。
表 9.12. 其他二进制串函数
函数 描述 例子 |
|---|
btrim( bytesbytea, bytesremovedbytea) → bytea
从bytes的开始和结束处删除只包含bytesremoved中出现的字节的最长字符串 btrim('\x1234567890'::bytea, '\x9012'::bytea)→ \x345678
|
get_bit( bytesbytea, nbigint) → integer
从二进制字符串中提取 n'th 位。 get_bit('\x1234567890'::bytea, 30)→ 1
|
get_byte( bytesbytea, ninteger) → integer
从二进制字符串中提取 n'th 字节。 get_byte('\x1234567890'::bytea, 4)→ 144
|
length( bytea) → integer
返回二进制字符串中的字节数。 length('\x1234567890'::bytea)→ 5
|
length( bytesbytea, encodingname) → integer
返回二进制字符串中的字符数,假设它是给定encoding中的文本。 length('jose'::bytea, 'UTF8')→ 4
|
md5( bytea) → text
计算二进制字符串的MD5 hash,结果以十六进制形式写入。 md5('Th\000omas'::bytea)→ 8ab2d3c9689aaf18b4958c334c82d8b1
|
set_bit( bytesbytea, nbigint, newvalueinteger) → bytea
设置二进制字符串中的n'th位为newvalue。 set_bit('\x1234567890'::bytea, 30, 0)→ \x1234563890
|
set_byte( bytesbytea, ninteger, newvalueinteger) → bytea
设置二进制字符串中的 n'th 字节到 newvalue。 set_byte('\x1234567890'::bytea, 4, 64)→ \x1234567840
|
sha224( bytea) → bytea
计算二进制字符串的 SHA-224 hash。 sha224('abc'::bytea)→ \x23097d223405d8228642a477bda255b32aadbce4bda0b3f7e36c9da7
|
sha256( bytea) → bytea
计算二进制字符串的 SHA-256 hash。 sha256('abc'::bytea)→ \xba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad
|
sha384( bytea) → bytea
计算二进制字符串的 SHA-384 hash。 sha384('abc'::bytea)→ \xcb00753f45a35e8bb5a03d699ac65007272c32ab0eded1631a8b605a43ff5bed8086072ba1e7cc2358baeca134c825a7
|
sha512( bytea) → bytea
计算二进制字符串的 SHA-512 hash。 sha512('abc'::bytea)→ \xddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f
|
substr( bytesbytea, startinteger[, countinteger] ) → bytea
从start字节开始提取bytes的子字符串,并扩展为count字节,如果这是指定的。 (与 substring(bytes从 start到 count)相同.) substr('\x1234567890'::bytea, 3, 2)→ \x5678
|
函数get_byte和set_byte把一个二进制串中的一个字节计数为字节 0。 函数get_bit和set_bit在每一个字节中从右边起计数位; 例如位 0 是第一个字节的最低有效位,而位 15 是第二个字节的最高有效位。
由于历史原因,函数md5返回的是一个十六进制编码的text值,而SHA-2函数返回类型bytea。 可以使用函数encode和decode在两者之间转换。 例如encode(sha256('abc'),'hex')可以得到一个十六进制编码的文本表示,或者decode(md5('abc'), 'hex')得到一个bytea值。
用于在不同字符集(编码)之间转换字符串的函数,以及用于以文本形式表示任意二进制数据的函数,在表 9.13中显示。 对于这些函数,类型为text的参数或结果表示为数据库的默认编码,而类型为 bytea的参数或结果表示为由另一个参数命名的编码。
表 9.13. Text/Binary String Conversion Functions
函数 描述 例子 |
|---|
convert( bytesbytea, src_encodingname, dest_encodingname) → bytea
将表示编码src_encoding的文本的二进制字符串转换为编码dest_encoding的二进制字符串 (适用的转换请参阅第 23.3.4 节)。 convert('text_in_utf8', 'UTF8', 'LATIN1')→ \x746578745f696e5f75746638
|
convert_from( bytesbytea, src_encodingname) → text
将表示编码src_encoding的文本的二进制字符串转换为数据库编码中的text。 (适用的转换请参阅 第 23.3.4 节 )。 convert_from('text_in_utf8', 'UTF8')→ text_in_utf8
|
convert_to( stringtext, dest_encodingname) → bytea
将text字符串(数据库编码)转换为编码dest_encoding中编码的二进制字符串。 (适用的转换请参阅 第 23.3.4 节 )。 convert_to('some_text', 'UTF8')→ \x736f6d655f74657874
|
encode( bytesbytea, formattext) → text
将二进制数据编码成文本表示;支持的format值为: base64, escape, hex. encode('123\000\001', 'base64')→ MTIzAAE=
|
decode( stringtext, formattext) → bytea
从文本表示中解码二进制数据;支持的format值与encode相同。 decode('MTIzAAE=', 'base64')→ \x3132330001
|
encode和 decode函数支持以下文本格式:
- base64
base64格式是RFC 2045 Section 6.8。 根据RFC,编码的行被分割为76个字符。但是,作为MIME CRLF行结束标记的替代,只有换行符用于行结束。 decode函数忽略回车、换行、空格和制表符。 否则,当decode被提供了无效的base64数据—包括结尾填充不正确时。
- escape
escape格式将零字节和设置了高位的字节转换为八进制转义序列(\nnn),并将反斜杠加倍。 其他字节值按字面意思表示。 decode函数如果反斜杠后面没有第二个反斜杠或三个八进制数字将引发错误;它接受其他未变化的字节值。
- hex
hex格式将每4位数据表示为一个十六进制数字,从0到f,首先写入每个字节的高阶数字。 encode函数输出a-f的十六进制小写数字。 因为数据的最小单位是8位,所以 encode总是返回偶数个字符。 decode函数接受大写或小写的a-f字符。 当decode给出无效的十六进制数据—时将引发一个错误,包括给定奇数个字符时。
参见第 9.21 节中的聚集函数string_agg以及第 34.4 节中的大对象函数。