您现在的位置是:首页 > 博客网站制作 > 心得笔记心得笔记

PostgreSQL 字符串处理与日期处理操作

杨青青2022-02-20【心得笔记】人已围观

简介这篇文章主要介绍了PostgreSQL字符串处理与日期处理操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧。字符串长度、大小写1SELECTCHAR_LENGTH('test')--

这篇文章主要介绍了PostgreSQL字符串处理与日期处理操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧。

字符串长度、大小写

1SELECTCHAR_LENGTH('test')--字符串长度
SELECTLENGTH('test')
LENGTH(string,encodingname)
SELECTLENGTH('测试','UTF-8');
LOWER(string)或者UPPER(string)--大小写
ASCII(string)
SELECTASCII('abc')--结果是'a'的ascii码

字符串格式化

1FORMAT(formatstrtext[,formatarg"any"[,...]])--类似于printf

字符串拼接

SELECT'number'||123--字符串连接
CONCAT(str"any"[,str"any"[,...]])
CONCAT_WS(septext,str"any"[,str"any"[,...]])
SELECT*FROMCONCAT_WS('#','hello','world')

字符串剪切与截取

LPAD(stringtext,lengthint[,filltext])
RPAD(stringtext,lengthint[,filltext])
SELECTLPAD('12345',10,'0')--结果"0000012345"
TRIM([leading|trailing|both][characters]fromstring)
SELECTTRIM(both''from'helloworld')--结果是'helloworld'
BTRIM(stringtext[,characterstext])
RTRIM(stringtext[,characterstext])
LTRIM(stringtext[,characterstext])
SELECTBTRIM('yyhelloworldyyyy','y')--结果是'helloworld'
LEFT(strtext,nint)--返回字符串前n个字符,n为负数时返回除最后|n|个字符以外的所有字符
RIGHT(strtext,nint)
SUBSTRING(stringfromint[forint])
SELECTSUBSTRING('helloworld'from7for5)--结果是'world'

字符串加引号

QUOTE_IDENT(stringtext)
QUOTE_LITERAL(STRINGTEXT)
QUOTE_LITERAL(valueanyelement)
SELECT'l''host"'--结果是'l'host"'
SELECTQUOTE_LITERAL('l''host"')--结果是'l''host"'

字符串分割

SPLIT_PART(stringtext,delimitertext,fieldint)
REGEXP_SPLIT_TO_ARRAY(stringtext,patterntext[,flagstext])
REGEXP_SPLIT_TO_TABLE(stringtext,patterntext[,flagstext])
SELECTSPLIT_PART('hello#world','#',2)--结果是'world'
SELECTREGEXP_SPLIT_TO_ARRAY('hello#world','#')--结果是{hello,world}
SELECTREGEXP_SPLIT_TO_TABLE('hello#world','#')assplit_res--结果是两行,第一行hello,第二行world

字符串查找、反转与替换

POSITION(substringinstring)--查找
SELECTPOSITION('h'in'helloworld')--结果是1,这里从1开始计数
REVERSE(str)
REPEAT(stringtext,numberint)
REPLACE(string,string,string)
SELECTREPLACE('helloworld','','#')
REGEXP_MATCHES(stringtext,patterntext[,flagstext])
REGEXP_REPLACE(stringtext,patterntext,replacementtext[,flagstext])
SELECTREGEXP_MATCHES('helloworld','.o.','g')--返回两行,第一行是'lo',第二行是'wor'
SELECTREGEXP_MATCHES('helloworld','.o.')--返回第一个匹配,'lo'

时间处理

SELECTTO_CHAR(TO_TIMESTAMP(CREATE_TIME),'YYYY-MM-DDHH24:MI:SS')
SELECTEXTRACT(YEARFROMNOW());

补充:postgresql处理时间函数截取hh:mm/yyyy-mm-dd

1.to_timestamp:

1ANDto_timestamp(a.upload_time,'yyyy-MM-dd')>='"+startTime+"'andto_timestamp(a.upload_time,'yyyy-MM-dd')<='"+endTime+"'

2.substring:

1substring('2019-04-0814:18:09',index,k):

数值代表含义index:代表从index开始截取数据,k代表从index开始截取到第k个数据

处理对象:时间为字符串格式的数据

eg:

截取时间到年-月-日:

1SELECTsubstring(upload_time,1,10)fromtableWHEREupload_time='2019-04-0814:18:09'

结果:2019-04-08

截取时间到时:分:

1SELECTsubstring(upload_time,12,5)fromtableWHEREupload_time='2019-04-0814:18:09'

结果:14:18

Tags:

很赞哦! ()

文章评论

站点信息

  • 建站时间:2011年01月12日
  • 网站程序:帝国CMS7.5
  • 主题模板《今夕何夕》
  • 文章统计625篇文章
  • 标签管理标签云
  • 微信公众号:扫描二维码,关注我们