本节描述那些检查和操作类型为bytea
的值的函数和操作符。
SQL定义了一些使用关键字而不是逗号来分割参数的串函数。详情请见表 9.11。PostgreSQL也提供了这些函数使用常规函数调用语法的版本(参阅表 9.12)。
本页中显示的示例结果假设服务器参数bytea_output
被设置为escape
(传统PostgreSQL格式)。
表 9.11. SQL二进制串函数和操作符
函数 | 返回类型 | 描述 | 例子 | 结果 |
---|---|---|---|---|
| bytea | 串连接 | E'\\\\Post'::bytea || E'\047円gres\000円'::bytea | \\Post'gres000円 |
| int | 二进制串中的字节数 | octet_length(E'jo\000円se'::bytea) | 5 |
| bytea | 替换子串 | overlay(E'Th\000円omas'::bytea placing E'\002円\003円'::bytea from 2 for 3) | T\002円\003円mas |
| int | 指定子串的位置 | position(E'\000円om'::bytea in E'Th\000円omas'::bytea) | 3 |
| bytea | 提取子串 | substring(E'Th\000円omas'::bytea from 2 for 3) | h000円o |
| bytea | 从string 的开头或结尾删除只包含出现在bytes 中的字节的最长串
| trim(E'\000円\001円'::bytea from E'\000円Tom\001円'::bytea) | Tom |
还有一些二进制串处理函数可以使用,在表 9.12列出。 其中有一些是在内部使用,用于实现表 9.11列出的 SQL 标准串函数。
表 9.12. 其他二进制串函数
get_byte
和set_byte
把一个二进制串中的一个字节计数为字节 0。get_bit
和set_bit
在每一个字节中从右边起计数位;例如位 0 是第一个字节的最低有效位,而位 15 是第二个字节的最高有效位。