返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

9.5. 二进制字符串函数和操作符

发布于 2019-09-30 03:06:08 字数 4158 浏览 1084 评论 0 收藏 0

本节描述那些检查和操作类型为 bytea 数值的函数和操作符。

SQL 定义了一些有特殊语法的字符串函数,在这些函数里使用特殊关键字而不是逗号来分隔参数。详情请见表9-8。一些函数也实现了使用常用语法进行函数调用的方法(参阅表9-9)。

表9-8. SQL 二进制字符串函数和操作符

函数返回类型描述例子结果
string || stringbytea字符串连接E'\\\\Post'::bytea || E'\\047gres\\000'::bytea\\Post'gres\000
get_bit(string, offset)int从字符串中抽取位get_bit(E'Th\\000omas'::bytea, 45)1
get_byte(string, offset)int从字符串中抽取字节get_byte(E'Th\\000omas'::bytea, 4)109
octet_length(string)int二进制字符串中的字节数octet_length( E'jo\\000se'::bytea)5
position(substring in string)int特定子字符串的位置position(E'\\000om'::bytea in E'Th\\000omas'::bytea)3
set_bit(string, offset, newvalue)bytea设置字符串中的位set_bit(E'Th\\000omas'::bytea, 45, 0)Th\000omAs
set_byte(string, offset, newvalue)bytea设置字符串中的字节set_byte(E'Th\\000omas'::bytea, 4, 64)Th\000o@as
substring(string [from int] [for int])bytea抽取子字符串substring(E'Th\\000omas'::bytea from 2 for 3)h\000o
trim([both] bytes from string)byteastring 的开头和结尾删除只包含 bytes 中字节的最长字符串trim(E'\\000'::bytea from E'\\000Tom\\000'::bytea)Tom

还有一些二进制字符串处理函数可以使用,在表9-9列出。其中有一些是在内部使用,用于实现表9-8列出的 SQL 标准的字符串函数。

表9-9. 其它二进制字符串函数

函数返回类型描述例子结果
btrim(string bytea, bytes bytea)byteastring 的开头和结尾删除只包含 bytes 中字节的最长的字符串btrim(E'\\000trim\\000'::bytea, E'\\000'::bytea)trim
decode(string text, type text)bytea把之前用 encode 编码的结果 string 解码为二进制字符串。参数类型和 encode 相同。decode(E'123\\000456', 'escape')123\000456
encode(string bytea, type text)text把二进制字符串编码为只包含 ASCII 的表现形式。支持:base64, hex, escapeencode(E'123\\000456'::bytea, 'escape')123\000456
length(string)int二进制字符串的长度length(E'jo\\000se'::bytea)5
md5(string)text计算 string 的MD5散列值,以十六进制方式返回结果。md5(E'Th\\000omas'::bytea)8ab2d3c9689aaf18 b4958c334c82d8b1

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文