PostgreSQL 字符串处理与日期处理操作
字符串长度、大小写
SELECTCHAR_LENGTH('test')--字符串长度 SELECTLENGTH('test') LENGTH(string,encodingname) SELECTLENGTH('测试','UTF-8'); LOWER(string)或者UPPER(string)--大小写 ASCII(string) SELECTASCII('abc')--结果是'a'的ascii码
字符串格式化
FORMAT(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:
ANDto_timestamp(a.upload_time,'yyyy-MM-dd')>='"+startTime+"'andto_timestamp(a.upload_time,'yyyy-MM-dd')<='"+endTime+"'
2.substring:
substring('2019-04-0814:18:09',index,k):
数值代表含义index:代表从index开始截取数据,k代表从index开始截取到第k个数据
处理对象:时间为字符串格式的数据
eg:
截取时间到年-月-日:
SELECTsubstring(upload_time,1,10)fromtableWHEREupload_time='2019-04-0814:18:09'
结果:2019-04-08
截取时间到时:分:
SELECTsubstring(upload_time,12,5)fromtableWHEREupload_time='2019-04-0814:18:09'
结果:14:18
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。