经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » PostgreSQL » 查看文章
PostgreSQL 字符串处理与日期处理操作
来源:jb51  时间:2021/2/1 13:48:48  对本文有异议

字符串长度、大小写

  1. SELECT CHAR_LENGTH('test') -- 字符串长度
  2. SELECT LENGTH('test')
  3. LENGTH(string,encoding name)
  4. SELECT LENGTH('测试','UTF-8');
  5. LOWER(string) 或者 UPPER(string) -- 大小写
  6. ASCII(string)
  7. SELECT ASCII('abc') -- 结果是'a'ascii

字符串格式化

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

字符串拼接

  1. SELECT 'number' || 123 --字符串连接
  2. CONCAT(str "any" [, str "any" [, ...] ])
  3. CONCAT_WS(sep text, str "any" [,str "any" [, ...] ])
  4. SELECT * FROM CONCAT_WS('#','hello','world')

字符串剪切与截取

  1. LPAD(string text, length int [,fill text])
  2. RPAD(string text, length int [,fill text])
  3. SELECT LPAD('12345', 10,'0') -- 结果 "0000012345"
  4. TRIM([leading | trailing | both] [characters] from string)
  5. SELECT TRIM(both ' ' from ' hello world') -- 结果是'hello world'
  6. BTRIM(string text [, characters text])
  7. RTRIM(string text [, characterstext])
  8. LTRIM(string text [, characterstext])
  9. SELECT BTRIM('yyhello worldyyyy','y') -- 结果是'hello world'
  10. LEFT(str text, n int) -- 返回字符串前n个字符,n为负数时返回除最后|n|个字符以外的所有字符
  11. RIGHT(str text, n int)
  12. SUBSTRING(string from int [for int])
  13. SELECT SUBSTRING('hello world' from 7 for 5) -- 结果是'world'

字符串加引号

  1. QUOTE_IDENT(string text)
  2. QUOTE_LITERAL(STRING TEXT)
  3. QUOTE_LITERAL(value anyelement)
  4. SELECT 'l''host"' -- 结果是'l'host"'
  5. SELECT QUOTE_LITERAL('l''host"') -- 结果是'l''host"'

字符串分割

  1. SPLIT_PART(string text,delimiter text, field int)
  2. REGEXP_SPLIT_TO_ARRAY(stringtext, pattern text [, flags text])
  3. REGEXP_SPLIT_TO_TABLE(stringtext, pattern text [, flagstext])
  4. SELECT SPLIT_PART('hello#world','#',2) -- 结果是'world'
  5. SELECT REGEXP_SPLIT_TO_ARRAY('hello#world','#') -- 结果是{hello,world}
  6. SELECT REGEXP_SPLIT_TO_TABLE('hello#world','#') as split_res -- 结果是两行,第一行hello,第二行world

字符串查找、反转与替换

  1. POSITION(substring in string) -- 查找
  2. SELECT POSITION('h' in 'hello world') -- 结果是1,这里从1开始计数
  3. REVERSE(str)
  4. REPEAT(string text, number int)
  5. REPLACE(string,string,string)
  6. SELECT REPLACE('hello world',' ','#')
  7. REGEXP_MATCHES(string text,pattern text [, flags text])
  8. REGEXP_REPLACE(string text,pattern text,replacement text[, flags text])
  9. SELECT REGEXP_MATCHES('hello world','.o.','g') -- 返回两行,第一行是'lo ',第二行是'wor'
  10. SELECT REGEXP_MATCHES('hello world','.o.') -- 返回第一个匹配,'lo '

时间处理

  1. SELECT TO_CHAR(TO_TIMESTAMP(CREATE_TIME),'YYYY-MM-DD HH24:MI:SS')
  2. SELECT EXTRACT(YEAR FROM NOW());

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

1.to_timestamp:

  1. AND to_timestamp(a.upload_time,'yyyy-MM-dd')>='"+startTime+"' and to_timestamp(a.upload_time,'yyyy-MM-dd') <= '"+endTime+"'

2.substring:

  1. substring('2019-04-08 14:18:09',index,k):

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

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

eg:

截取时间到 年-月-日:

  1. SELECT substring(upload_time,1,10) from table WHERE upload_time='2019-04-08 14:18:09'

结果:2019-04-08

截取时间到 时:分:

  1. SELECT substring(upload_time,12,5) from table WHERE upload_time='2019-04-08 14:18:09'

结果:14:18

以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。如有错误或未考虑完全的地方,望不吝赐教。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号