返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

9.4. 字符串函数和操作符

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

本节描述了用于检查和操作字符串数值的函数和操作符。在这个环境中的字符串包括所有 character, character varying, text 类型的值。除非另外说明,所有下面列出的函数都可以处理这些类型,不过要小心的是,在使用 character 类型的时候,需要注意自动填充的潜在影响。通常这里描述的函数也能用于非字符串类型,我们只要先把那些数据转化为字符串表现形式就可以了。有些函数还可以处理位串类型。

SQL 定义了一些字符串函数,它们有指定的语法(用特定的关键字而不是逗号来分隔参数)。详情请见表9-5,这些函数也用正常的函数调用语法实现了(参阅表9-6)。

表9-5. SQL 字符串函数和操作符

函数返回类型描述例子结果
string || stringtext字符串连接'Post' || 'greSQL'PostgreSQL
bit_length(string)int字符串里二进制位的个数bit_length('jose')32
char_length(string)character_length(string)int字符串中的字符个数char_length('jose')4
convert(string using conversion_name)text使用指定的转换名字改变编码。转换可以通过 CREATE CONVERSION 定义。当然系统里有一些预定义的转换名字。参阅表9-7获取可用的转换名。convert('PostgreSQL' using iso_8859_1_to_utf8)UTF8编码的 'PostgreSQL'
lower(string)text把字符串转化为小写lower('TOM')tom
octet_length(string)int字符串中的字节数octet_length('jose')4
overlay(string placing string from int [for int])text替换子字符串overlay('Txxxxas' placing 'hom' from 2 for 4)Thomas
position(substring in string)int指定的子字符串的位置position('om' in 'Thomas')3
substring(string [from int] [for int])text抽取子字符串substring('Thomas' from 2 for 3)hom
substring(string from pattern)text抽取匹配 POSIX 正则表达式的子字符串。参见节9.7获取更多关于模式匹配的信息。substring('Thomas' from '...$')mas
substring(string from pattern for escape)text抽取匹配 SQL 正则表达式的子字符串。参见节9.7获取更多关于模式匹配的信息。substring('Thomas' from '%#"o_a#"_' for '#')oma
trim([leading | trailing | both] [characters] from string)text从字符串 string 的开头/结尾/两边删除只包含 characters 中字符(缺省是一个空白)的最长的字符串trim(both 'x' from 'xTomxx')Tom
upper(string)text把字符串转化为大写upper('tom')TOM

还有额外的字符串操作函数可以用,它们在表9-6列出。它们有些在内部用于实现表9-5列出的 SQL 标准字符串函数。

表9-6. 其它字符串函数

函数返回类型描述例子结果
ascii(string)int参数第一个字符的 ASCII 码ascii('x')120
btrim(string text [, characters text])textstring 开头和结尾删除只包含 characters 中字符(缺省是空白)的最长字符串btrim('xyxtrimyyx', 'xy')trim
chr(int)text给出 ASCII 码的字符chr(65)A
convert(string text, [src_encoding name,] dest_encoding name)text把原来编码为 src_encoding 的字符串转换为 dest_encoding 编码(如果省略了 src_encoding 将使用数据库编码)convert( 'text_in_utf8', 'UTF8', 'LATIN1')以ISO 8859-1编码表示的 text_in_utf8
decode(string text, type text)bytea把早先用 encode 编码的 string 里面的二进制数据解码。参数类型和 encode 相同。decode('MTIzAAE=', 'base64')123\000\001
encode(data bytea, type text)text把二进制数据编码为只包含 ASCII 形式的数据。支持的类型有:base64, hex, escapeencode( E'123\\000\\001', 'base64')MTIzAAE=
initcap(string)text把每个单词的第一个子母转为大写,其它的保留小写。单词是一系列字母数字组成的字符,用非字母数字分隔。initcap('hi THOMAS')Hi Thomas
length(string)intstring 中字符的数目length('jose')4
lpad(string text, length int [, fill text])text通过填充字符 fill(缺省时为空白),把 string 填充为 length 长度。如果 string 已经比 length 长则将其尾部截断。lpad('hi', 5, 'xy')xyxhi
ltrim(string text [, characters text])text从字符串 string 的开头删除只包含 characters 中字符(缺省是一个空白)的最长的字符串。ltrim('zzzytrim', 'xyz')trim
md5(string)text计算 string 的MD5散列,以十六进制返回结果。md5('abc')900150983cd24fb0 d6963f7d28e17f72
pg_client_encoding()name当前客户端编码名称pg_client_encoding()SQL_ASCII
quote_ident(string)text返回适用于 SQL 语句的标识符形式(使用适当的引号进行界定)。只有在必要的时候才会添加引号(字符串包含非标识符字符或者会转换大小写的字符)。嵌入的引号被恰当地写了双份。quote_ident('Foo bar')"Foo bar"
quote_literal(string)text返回适用于在 SQL 语句里当作文本使用的形式。嵌入的引号和反斜杠被恰当地写了双份。quote_literal( 'O\'Reilly')'O''Reilly'
regexp_replace(string text, pattern text, replacement text [,flags text])text替换匹配 POSIX 正则表达式的子字符串。参见节9.7以获取更多模式匹配的信息。regexp_replace('Thomas', '.[mN]a.', 'M')ThM
repeat(string text, number int)textstring 重复 numberrepeat('Pg', 4)PgPgPgPg
replace(string text, from text, to text)text把字符串 string 里出现地所有子字符串 from 替换成子字符串 toreplace( 'abcdefabcdef', 'cd', 'XX')abXXefabXXef
rpad(string text, length int [, fill text])text使用填充字符 fill(缺省时为空白),把 string 填充到 length 长度。如果 string 已经比 length 长则将其从尾部截断。rpad('hi', 5, 'xy')hixyx
rtrim(string text [, characters text])text从字符串 string 的结尾删除只包含 characters 中字符(缺省是个空白)的最长的字符串。rtrim('trimxxxx', 'x')trim
split_part(string text, delimiter text, field int)text根据 delimiter 分隔 string 返回生成的第 field 个子字符串(1为基)。split_part('abc~@~def~@~ghi', '~@~', 2)def
strpos(string, substring)int指定的子字符串的位置。和 position(substring in string) 一样,不过参数顺序相反。strpos('high', 'ig')2
substr(string, from [, count])text抽取子字符串。和 substring(string from from for count) 一样substr('alphabet', 3, 2)ph
to_ascii(string text [, encoding text])textstring 从其它编码转换为 ASCII (仅支持 LATIN1, LATIN2, LATIN9, WIN1250 编码)。to_ascii('Karel')Karel
to_hex(number intbigint)textnumber 转换成十六进制表现形式to_hex(2147483647)7fffffff
translate(string text, from text, to text)text把在 string 中包含的任何匹配 from 中字符的字符转化为对应的在 to 中的字符translate('12345', '14', 'ax')a23x5

表9-7. 内置的转换

转换名[a]源编码目的编码
ascii_to_micSQL_ASCIIMULE_INTERNAL
ascii_to_utf8SQL_ASCIIUTF8
big5_to_euc_twBIG5EUC_TW
big5_to_micBIG5MULE_INTERNAL
big5_to_utf8BIG5UTF8
euc_cn_to_micEUC_CNMULE_INTERNAL
euc_cn_to_utf8EUC_CNUTF8
euc_jp_to_micEUC_JPMULE_INTERNAL
euc_jp_to_sjisEUC_JPSJIS
euc_jp_to_utf8EUC_JPUTF8
euc_kr_to_micEUC_KRMULE_INTERNAL
euc_kr_to_utf8EUC_KRUTF8
euc_tw_to_big5EUC_TWBIG5
euc_tw_to_micEUC_TWMULE_INTERNAL
euc_tw_to_utf8EUC_TWUTF8
gb18030_to_utf8GB18030UTF8
gbk_to_utf8GBKUTF8
iso_8859_10_to_utf8LATIN6UTF8
iso_8859_13_to_utf8LATIN7UTF8
iso_8859_14_to_utf8LATIN8UTF8
iso_8859_15_to_utf8LATIN9UTF8
iso_8859_16_to_utf8LATIN10UTF8
iso_8859_1_to_micLATIN1MULE_INTERNAL
iso_8859_1_to_utf8LATIN1UTF8
iso_8859_2_to_micLATIN2MULE_INTERNAL
iso_8859_2_to_utf8LATIN2UTF8
iso_8859_2_to_windows_1250LATIN2WIN1250
iso_8859_3_to_micLATIN3MULE_INTERNAL
iso_8859_3_to_utf8LATIN3UTF8
iso_8859_4_to_micLATIN4MULE_INTERNAL
iso_8859_4_to_utf8LATIN4UTF8
iso_8859_5_to_koi8_rISO_8859_5KOI8
iso_8859_5_to_micISO_8859_5MULE_INTERNAL
iso_8859_5_to_utf8ISO_8859_5UTF8
iso_8859_5_to_windows_1251ISO_8859_5WIN1251
iso_8859_5_to_windows_866ISO_8859_5WIN866
iso_8859_6_to_utf8ISO_8859_6UTF8
iso_8859_7_to_utf8ISO_8859_7UTF8
iso_8859_8_to_utf8ISO_8859_8UTF8
iso_8859_9_to_utf8LATIN5UTF8
johab_to_utf8JOHABUTF8
koi8_r_to_iso_8859_5KOI8ISO_8859_5
koi8_r_to_micKOI8MULE_INTERNAL
koi8_r_to_utf8KOI8UTF8
koi8_r_to_windows_1251KOI8WIN1251
koi8_r_to_windows_866KOI8WIN866
mic_to_asciiMULE_INTERNALSQL_ASCII
mic_to_big5MULE_INTERNALBIG5
mic_to_euc_cnMULE_INTERNALEUC_CN
mic_to_euc_jpMULE_INTERNALEUC_JP
mic_to_euc_krMULE_INTERNALEUC_KR
mic_to_euc_twMULE_INTERNALEUC_TW
mic_to_iso_8859_1MULE_INTERNALLATIN1
mic_to_iso_8859_2MULE_INTERNALLATIN2
mic_to_iso_8859_3MULE_INTERNALLATIN3
mic_to_iso_8859_4MULE_INTERNALLATIN4
mic_to_iso_8859_5MULE_INTERNALISO_8859_5
mic_to_koi8_rMULE_INTERNALKOI8
mic_to_sjisMULE_INTERNALSJIS
mic_to_windows_1250MULE_INTERNALWIN1250
mic_to_windows_1251MULE_INTERNALWIN1251
mic_to_windows_866MULE_INTERNALWIN866
sjis_to_euc_jpSJISEUC_JP
sjis_to_micSJISMULE_INTERNAL
sjis_to_utf8SJISUTF8
tcvn_to_utf8WIN1258UTF8
uhc_to_utf8UHCUTF8
utf8_to_asciiUTF8SQL_ASCII
utf8_to_big5UTF8BIG5
utf8_to_euc_cnUTF8EUC_CN
utf8_to_euc_jpUTF8EUC_JP
utf8_to_euc_krUTF8EUC_KR
utf8_to_euc_twUTF8EUC_TW
utf8_to_gb18030UTF8GB18030
utf8_to_gbkUTF8GBK
utf8_to_iso_8859_1UTF8LATIN1
utf8_to_iso_8859_10UTF8LATIN6
utf8_to_iso_8859_13UTF8LATIN7
utf8_to_iso_8859_14UTF8LATIN8
utf8_to_iso_8859_15UTF8LATIN9
utf8_to_iso_8859_16UTF8LATIN10
utf8_to_iso_8859_2UTF8LATIN2
utf8_to_iso_8859_3UTF8LATIN3
utf8_to_iso_8859_4UTF8LATIN4
utf8_to_iso_8859_5UTF8ISO_8859_5
utf8_to_iso_8859_6UTF8ISO_8859_6
utf8_to_iso_8859_7UTF8ISO_8859_7
utf8_to_iso_8859_8UTF8ISO_8859_8
utf8_to_iso_8859_9UTF8LATIN5
utf8_to_johabUTF8JOHAB
utf8_to_koi8_rUTF8KOI8
utf8_to_sjisUTF8SJIS
utf8_to_tcvnUTF8WIN1258
utf8_to_uhcUTF8UHC
utf8_to_windows_1250UTF8WIN1250
utf8_to_windows_1251UTF8WIN1251
utf8_to_windows_1252UTF8WIN1252
utf8_to_windows_1253UTF8WIN1253
utf8_to_windows_1254UTF8WIN1254
utf8_to_windows_1255UTF8WIN1255
utf8_to_windows_1256UTF8WIN1256
utf8_to_windows_1257UTF8WIN1257
utf8_to_windows_866UTF8WIN866
utf8_to_windows_874UTF8WIN874
windows_1250_to_iso_8859_2WIN1250LATIN2
windows_1250_to_micWIN1250MULE_INTERNAL
windows_1250_to_utf8WIN1250UTF8
windows_1251_to_iso_8859_5WIN1251ISO_8859_5
windows_1251_to_koi8_rWIN1251KOI8
windows_1251_to_micWIN1251MULE_INTERNAL
windows_1251_to_utf8WIN1251UTF8
windows_1251_to_windows_866WIN1251WIN866
windows_1252_to_utf8WIN1252UTF8
windows_1256_to_utf8WIN1256UTF8
windows_866_to_iso_8859_5WIN866ISO_8859_5
windows_866_to_koi8_rWIN866KOI8
windows_866_to_micWIN866MULE_INTERNAL
windows_866_to_utf8WIN866UTF8
windows_866_to_windows_1251WIN866WIN
windows_874_to_utf8WIN874UTF8
【注意】a.
转换名遵循一个标准的命名模式:将源编码中的所有非字母数字字符用下划线替换,后面跟着 _to_ ,然后后面再跟着经过同样处理的目标编码的名字。因此这些名字可能和客户的编码名字不同。

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

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

发布评论

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