postgresql----字符串函数与操作符

函数 返回值类型 描述 示例 结果
string||string text 字符串连接 select ‘Post‘||‘gresql‘||‘ good!‘; Postgresql good!
string||non-string或non-string||string text 非字符串与字符串连接 select 1||‘ one‘; 1 one
bit_length(string) int 字符串的位数,注意一个汉字是3个字节 select bit_length(‘one‘); 24
char_length(string) int 字符串中字符的个数 select char_length(‘中国‘); 2
length(string) int 字符串中字符个数,同char_length(string) select length(‘中国‘); 2
length(string,encoding name) int 以name的编码格式字符串的字符个数 select length(‘中国‘,‘GBK‘); 3
octet_length(string) int 字符串的字节数 select octet_length(‘中国‘); 6
lower(string) text 将字符串转换成小写 select lower(‘HeLLO‘); hello
upper(string) text 将字符串转换成大写 select lower(‘HellO‘); HELLO
initcap(string) text 将字符串中每个单词的首字母大写 select initcap(‘hello world !‘); Hello World !
overlay(string placing string from int [for int]) text 替换字符串,其中第一个int是开始位置,第二个int是长度,如果没有第二个int则长度默认为第二个字符串的长度 select overlay(‘Txxxxas‘ placing ‘hom‘ from 2 for 4); Thomas
replace(string,string,string) text 替换字符串,将第一个字符串中的第二个字符串替换成第三个字符串 select replace(‘Txxxxas‘,‘xxxx‘,‘hom‘); Thomas
translate(string textfrom textto text) text 把string中from字符替换成对应to中的字符,如(‘text‘,‘tx‘,‘nd‘)中t->n,x->d,替换后结果为nedn;如果from比to长,则删除from多出的字符,如(‘Txxxxas‘,‘Txas‘,‘hom‘)结果为hooom;如果from中有重复字符,对应顺序也是一一对应的,但是重复字符以第一个为准,如(‘txxxa‘,‘xxx‘,‘abcd‘),结果为taaad
select translate(‘Txxxxas‘,‘xxxxa‘,‘hom‘);

select translate(‘Txxxxas‘,‘Txas‘,‘hom‘);

select translate(‘txxxa‘,‘xxxa‘,‘abcd‘);


Thhhhs

hoooom

taaad

position(substring in string) int 给定子字符串在字符串的位置 select position(‘lo‘ in ‘hello‘); 4
strpos(stringsubstring) int 功能同上,只是入参顺序相反
select strpos(‘hello‘,‘lo‘);


4

substring(string from int  [for int]) text 截取字符串,从from位置截取长度for,如果for省略,则是从from至结尾
select substring(‘hello world‘ from 2 for 3);

select substring(‘hello world‘ from 2);


ell

ell world

substring(string,from int[, for int]) text 同上 select substring(‘hello world‘,2,3); ell
substring(string from pattern) text 截取匹配posix正则表达式的字符串 select substring(‘hello world‘ from ‘...$‘); rld
substring(string from pattern for escape) text 截取匹配posix正则表达式的字符串,for为转移字符 select substring(‘Thomas‘ from ‘%#"o_a#"_‘ for ‘#‘); oma

trim([leading | trailing | both]

[characters] from string)

text 删除字符串头部(leading),尾部(trailing)或两边的空白活[characters]字符 select trim(both ‘x‘ from ‘xxjdhdxxxx‘); jdhd

trim([leading | trailing | both]

[from] string[, characters] )

text 同上 select trim(both from ‘  jdhd   ‘,‘ ‘); jdhd
btrim(string text [, characters text]) text 删除字符串两边指定的字符 select btrim(‘xxhhhxxx‘,‘x‘); hhh
rtrim(string text [, characterstext]) text 删除字符串尾部指定的字符 select rtrim(‘xxhhhxxx‘,‘x‘); xxhhh
ltrim(string text [, characterstext]) text 删除字符串开头指定的字符 select ltrim(‘xxhhhxxx‘,‘x‘); hhhxxx
ascii(string) int 字符串第一个字符的ASCII值
select ascii(‘xa‘);

select ascii(‘x‘);


120

120

chr(int) text 将数字转换成字符 select chr(65); A
concat(str "any" [, str "any" [, ...] ]) text 连接所有参数,个数不限,类型不限 select concat(‘x‘,‘man‘,3); xman3
concat_ws(sep textstr "any" [,str "any" [, ...] ]) text 功能同上,只是第一个参数是连接分隔符 select concat_ws(‘,‘,‘x‘,‘man‘,3); x,man,3
convert(string bytea,src_encoding namedest_encodingname) text 将字符串从指定编码转换至目的编码格式 select convert(‘Hello‘,‘UTF8‘,‘GBK‘); \x48656c6c6f
format(formatstr text [,formatarg "any" [, ...] ]) text 格式化字符串,类似C语言的sprintf,其中n$表示第n个参数 select format(‘Hello %s, %1$s‘, ‘World‘); Hello World, World
left(str textn int) text 返回字符串前n个字符,n为负数时返回除最后|n|个字符以外的所有字符 select left(‘hello‘,-2); hel
right(str textn int) text 返回字符串后n个字符,n为负数时返回除最前|n|个字符意外的所有字符 select right(‘hello‘,2); he
lpad(string textlength int [,fill text]) text 在字符串开头填充text至长度为length,缺省为空白,如果string的长度已经大于length,则会截断后面多余length的字符 select lpad(‘123‘,5,‘0‘); 00123
rpad(string textlength int [,fill text]) text 在字符串尾部填充text至长度为length,缺省为空白,如果string的长度已经大于length,则会截断后面多余length的字符 select rpad(‘he‘,1,‘o‘); h
md5(string) text 计算string的md5散列值,并以十六进制返回 select md5(‘hello‘); 5d41402abc4b2a76b9719d911017c592

parse_ident(qualified_identifiertext [,

strictmode booleanDEFAULT true ] )

text[] 将qualified_identifier拆分解析到一个数组中,以句点为分隔符。 select parse_ident(‘SomeSchema.someTable‘); {someschema,sometable}
pg_client_encoding() name 获取当前客户端编码 select pg_client_encoding(); UTF8
quote_ident(string text) text 返回适合SQL语句标志符且使用适当引号的字符串,在字符串两端加双引号,如果字符串中出现双引号,返回结果中将变成两个,如果有2个连续的单引号,返回时只有1个 select quote_ident(‘Foo"‘‘"bar‘); "Foo""‘""bar"
quote_literal(string text) text 功能同上,只是内嵌的单引号和双引号被原样保留 select quote_literal(‘Foo"‘‘bar‘); ‘Foo"‘‘bar‘
quote_literal(value anyelement) text 将给定值转成text select quote_literal(45); ‘45‘
quote_nullable(string text) text 功能同quote_literal(string text),只是参数是NULL时返回NULL    
quote_nullable(value anyelement) text 功能同quote_literal(value anyelement),只是参数为NULL时返回NULL    
repeat(string textnumber int) text 将string重复number次 select repeat(‘Hi‘,2); HiHi
split_part(string text,delimiter textfield int) text 将字符串string以delimiter进行分割,并返回第field个子串 select split_part(‘1#2#3‘,‘#‘,2); 2
to_hex(number int or bigint) text 将数值转换成十六进制 select to_hex(155); 9b
reverse(str) text 将字符串逆序输出 select reverse(‘hello‘); olleh
regexp_split_to_array(stringtextpattern text [, flags text]) text[] 将字符串匹配posix正则表达式分割为字符串数组 select regexp_split_to_array(‘hello world‘, E‘\\s+‘); {hello,world}
regexp_split_to_table(stringtextpattern text [, flagstext])
setof

text

功能同上,只是以单列形式返回 select regexp_split_to_table(‘hello world‘, E‘\\s+‘);
hello
world

regexp_matches(string text,pattern text [, flags text]) setof text[] 返回string中第一个匹配posix正则表达式的子串,如果flag=g,则返回所有 select regexp_matches(‘foobarbequebaz‘, ‘(b..)‘,‘g‘);
{bar}
{beq}
{baz}


regexp_replace(string text,pattern text,

replacement text[, flags text])

text 将匹配posix正则表达式的第一个子串替换成指定字符串,如果flag=g,则替换所有 select regexp_replace(‘Thomas‘, ‘.[mN]a.‘, ‘M‘); ThM

format格式化

格式说明符由 % 字符引进,格式为

%[ position ] type
组件的字段有:
position (optional)
n$ 格式的字符串,这里的n是要打印的参数的索引。索引为1表示在formatstr之后的第一个参数。如果省略了position,默认使用序列中的下一个参数。
type (required)
格式转换的类型用来产生格式说明符的输出。支持下列的类型:
s 格式参数值为简单的字符串。空值作为空字符串对待。
I 将参数值作为SQL标识符对待,如果需要,双写它。值为空是错误的。
L 引用参数值作为SQL文字。空值用字符串 NULL 显示,没有引用。
除了上述的格式说明符,特殊的序列 %% 可以用作输出 % 字符。

示例:

test=# SELECT format(‘Hello %s‘, ‘World‘);
   format
-------------
 Hello World
(1 row)

test=# SELECT format(‘Testing %s, %s, %s, %%‘, ‘one‘, ‘two‘, ‘three‘);
           format
----------------------------
 Testing one, two, three, %
(1 row)

test=# SELECT format(‘INSERT INTO %I VALUES(%L)‘, ‘Foo bar‘, E‘O\‘Reilly‘);
                  format
-------------------------------------------
 INSERT INTO "Foo bar" VALUES(‘O‘‘Reilly‘)
(1 row)
时间: 2024-07-31 14:35:15

postgresql----字符串函数与操作符的相关文章

PostgreSQL字符串函数——POSITION

今天因为要处理曾经的一个Bug产生的数据库字段内容冗余的问题,需要用到截取函数. 在网上翻阅了一下,找到了这个字符串函数POSITION. POSITION(substr IN str) POSITION(substr IN str) is a synonym for LOCATE(substr,str). 下面是官方文档的地址 https://www.postgresql.org/docs/9.3/static/functions-string.html 用的时候,是想去掉字段里的下划线.用过

postgresql——字符串函数

字符串函数: postgresql中的字符串函数有:计算字符串长度函数.字符串合并函数.字符串替换函数.字符串比较函数.查找指定字符串位置函数等. 1.计算字符串字符数和字符串长度的函数:char_length(str)和length(str) char_length(str)返回值为字符串str所包含的字符个数.一个多字节字符算作一个单字符. 例子:使用char_length函数计算字符串字符个数,如: testdb=# select char_length('date'),char_leng

postgresql字符串函数

函数 返回类型 描述 例子 结果 string || string text 字串连接 'Post' || 'greSQL' PostgreSQL bit_length(string) int 字串里二进制位的个数 bit_length('jose') 32 char_length(string) int 字串中的字符个数 char_length('jose') 4 convert(string using conversion_name) text 使用指定的转换名字改变编码. convert

PostgreSQL学习手册(五) 函数和操作符

PostgreSQL学习手册(五) 函数和操作符 一.逻辑操作符:    常用的逻辑操作符有:AND.OR和NOT.其语义与其它编程语言中的逻辑操作符完全相同. 二.比较操作符:    下面是PostgreSQL中提供的比较操作符列表: 操作符 描述 < 小于 > 大于 <= 小于或等于 >= 大于或等于 = 等于 != 不等于 比较操作符可以用于所有可以比较的数据类型.所有比较操作符都是双目操作符,且返回boolean类型.除了比较操作符以外,我们还可以使用BETWEEN语句,如

[转] PostgreSQL学习手册(函数和操作符)

一.逻辑操作符: 常用的逻辑操作符有:AND.OR和NOT.其语义与其它编程语言中的逻辑操作符完全相同. 二.比较操作符: 下面是PostgreSQL中提供的比较操作符列表: 操作符 描述 < 小于 > 大于 <= 小于或等于 >= 大于或等于 = 等于 != 不等于 比较操作符可以用于所有可以比较的数据类型.所有比较操作符都是双目操作符,且返回boolean类型.除了比较操作符以外,我们还可以使用BETWEEN语句,如:    a BETWEEN x AND y 等效于 a &g

postgresql--与字符串相关的函数和操作符

楔子 我们在筛选数据的时候,很多时候要对字符串进行一些处理,下面来看看postgresql支持哪些字符串的操作吧 数据集如下 select * from t; 支持字符串操作的函数或者操作符 || 将多个字符串进行拼接 -- 需要注意的是,在pgsql中,所有的字符串都必须用单引号,双引号的话会被解释为字段 -- 为什么这么设计,是因为在pgsql中存在着大小写的问题,不管你查询的时候字段是大写还是小写,pgsql都会给你转成小写 -- 可如果这个时候表中的字段是大写的话,那么就会报出字段不存在

PostgreSQL 存储过程/函数

1.有用的链接 postgresql 常用小函数 Postgresql数据库的一些字符串操作函数 PostgreSQL function里面调用function PostgreSQL学习手册(函数和操作符<二>) PostgreSQL的存储过程简单入门 2.建立块环境(执行环境) do language plpgsql $$ declare begin ... .. . end $$; 如 do language plpgsql $$ declare today date :=now(); y

sql常用格式化函数及字符串函数

一.常用格式化函数 1.日期转字符串 select to_char(current_timestamp, 'YYYY-MM-DD HH24:MI:SS') //2017-09-18 22:41:50 YYYY:年(4和更多位) MM:月份号(01-12) DD:一个月里的日(01-31) HH24:一天的小时数(00-23) MI:分钟(00-59) SS:秒(00-59) 2.字符串转日期 select to_date('2017-09-18','YYYY-MM-DD') //2017-09-

MySQL函数和操作符

圆括号(...) 比较函数和操作符 =等于 <=>空值安全的等于 <>或!= <=和> expr BETWEEN min AND max COALESCE(value,...)在后面的参数列表中返回第一个不为NULL的值 GREATEST(value,...)在后面的参数列表中,返回最大的值 expr IN (value1,value2,...)若expr在后面的参数列表中存在,返回1,否则返回0 逻辑运算符 NOT,! AND,&& OR,|| XOR

字符串函数与过程

字符串函数 1.求长度length 定义:function Length(S: String): Integer; 例子: var S: String; begin Readln (S); Writeln('"', S, '"'); Writeln('length = ', Length(S)); end. 2.复制子串copy 定义: function Copy(S: String; Index: Integer; Count: Integer): String; 注意:S 是字符串