PostgreSQL 字符串處理與日期處理操作
字符串長度、大小寫
SELECT CHAR_LENGTH('test') -- 字符串長度 SELECT LENGTH('test') LENGTH(string,encoding name) SELECT LENGTH('測試','UTF-8'); LOWER(string) 或者 UPPER(string) -- 大小寫 ASCII(string) SELECT ASCII('abc') -- 結(jié)果是'a'的ascii碼
字符串格式化
FORMAT(formatstr text [,formatarg "any" [, ...] ]) -- 類似于printf
字符串拼接
SELECT 'number' || 123 --字符串連接 CONCAT(str "any" [, str "any" [, ...] ]) CONCAT_WS(sep text, str "any" [,str "any" [, ...] ]) SELECT * FROM CONCAT_WS('#','hello','world')
字符串剪切與截取
LPAD(string text, length int [,fill text]) RPAD(string text, length int [,fill text]) SELECT LPAD('12345', 10,'0') -- 結(jié)果 "0000012345" TRIM([leading | trailing | both] [characters] from string) SELECT TRIM(both ' ' from ' hello world') -- 結(jié)果是'hello world' BTRIM(string text [, characters text]) RTRIM(string text [, characterstext]) LTRIM(string text [, characterstext]) SELECT BTRIM('yyhello worldyyyy','y') -- 結(jié)果是'hello world' LEFT(str text, n int) -- 返回字符串前n個(gè)字符,n為負(fù)數(shù)時(shí)返回除最后|n|個(gè)字符以外的所有字符 RIGHT(str text, n int) SUBSTRING(string from int [for int]) SELECT SUBSTRING('hello world' from 7 for 5) -- 結(jié)果是'world'
字符串加引號
QUOTE_IDENT(string text) QUOTE_LITERAL(STRING TEXT) QUOTE_LITERAL(value anyelement) SELECT 'l''host"' -- 結(jié)果是'l'host"' SELECT QUOTE_LITERAL('l''host"') -- 結(jié)果是'l''host"'
字符串分割
SPLIT_PART(string text,delimiter text, field int) REGEXP_SPLIT_TO_ARRAY(stringtext, pattern text [, flags text]) REGEXP_SPLIT_TO_TABLE(stringtext, pattern text [, flagstext]) SELECT SPLIT_PART('hello#world','#',2) -- 結(jié)果是'world' SELECT REGEXP_SPLIT_TO_ARRAY('hello#world','#') -- 結(jié)果是{hello,world} SELECT REGEXP_SPLIT_TO_TABLE('hello#world','#') as split_res -- 結(jié)果是兩行,第一行hello,第二行world
字符串查找、反轉(zhuǎn)與替換
POSITION(substring in string) -- 查找 SELECT POSITION('h' in 'hello world') -- 結(jié)果是1,這里從1開始計(jì)數(shù) REVERSE(str) REPEAT(string text, number int) REPLACE(string,string,string) SELECT REPLACE('hello world',' ','#') REGEXP_MATCHES(string text,pattern text [, flags text]) REGEXP_REPLACE(string text,pattern text,replacement text[, flags text]) SELECT REGEXP_MATCHES('hello world','.o.','g') -- 返回兩行,第一行是'lo ',第二行是'wor' SELECT REGEXP_MATCHES('hello world','.o.') -- 返回第一個(gè)匹配,'lo '
時(shí)間處理
SELECT TO_CHAR(TO_TIMESTAMP(CREATE_TIME),'YYYY-MM-DD HH24:MI:SS') SELECT EXTRACT(YEAR FROM NOW());
補(bǔ)充:postgresql處理時(shí)間函數(shù) 截取hh:mm/yyyy-mm-dd
1.to_timestamp:
AND to_timestamp(a.upload_time,'yyyy-MM-dd')>='"+startTime+"' and to_timestamp(a.upload_time,'yyyy-MM-dd') <= '"+endTime+"'
2.substring:
substring('2019-04-08 14:18:09',index,k):
數(shù)值代表含義 index:代表從index開始截取數(shù)據(jù),k代表從index開始截取到第k個(gè)數(shù)據(jù)
處理對象:時(shí)間為字符串格式的數(shù)據(jù)
eg:
截取時(shí)間到 年-月-日:
SELECT substring(upload_time,1,10) from table WHERE upload_time='2019-04-08 14:18:09'
結(jié)果:2019-04-08
截取時(shí)間到 時(shí):分:
SELECT substring(upload_time,12,5) from table WHERE upload_time='2019-04-08 14:18:09'
結(jié)果:14:18
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL?數(shù)組類型操作使用及特點(diǎn)詳解
這篇文章主要為大家介紹了PostgreSQL?數(shù)組類型操作使用及特點(diǎn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10PostgreSQL數(shù)據(jù)庫性能調(diào)優(yōu)的注意點(diǎn)以及pg數(shù)據(jù)庫性能優(yōu)化方式
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫性能調(diào)優(yōu)的注意點(diǎn)以及pg數(shù)據(jù)庫性能優(yōu)化方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Postgresql?REGEXP開頭的正則函數(shù)用法圖文詳解
正則表達(dá)式是指一個(gè)用來描述或者匹配一系列符合某個(gè)句法規(guī)則的字符串的單個(gè)字符串,下面這篇文章主要給大家介紹了關(guān)于Postgresql?REGEXP開頭的正則函數(shù)用法的相關(guān)資料,需要的朋友可以參考下2024-02-02psql 執(zhí)行文件 permission denied的解決
這篇文章主要介紹了psql 執(zhí)行文件 permission denied的解決,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01postgresql 補(bǔ)齊空值、自定義查詢字段并賦值操作
這篇文章主要介紹了postgresql 補(bǔ)齊空值、自定義查詢字段并賦值操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01PostgreSQL中Slony-I同步復(fù)制部署教程
這篇文章主要給大家介紹了關(guān)于PostgreSQL中Slony-I同步復(fù)制部署的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用PostgreSQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06基于postgresql查詢某個(gè)字段屬于哪個(gè)表的說明
這篇文章主要介紹了基于postgresql查詢某個(gè)字段屬于哪個(gè)表的說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01postgresql數(shù)據(jù)庫連接數(shù)和狀態(tài)查詢操作
這篇文章主要介紹了postgresql數(shù)據(jù)庫連接數(shù)和狀態(tài)查詢操作,具有很好的參考價(jià)值,對大家有所幫助。一起跟隨小編過來看看吧2021-02-02如何修改Postgresql默認(rèn)賬號postgres的密碼
PostgreSQL數(shù)據(jù)庫創(chuàng)建一個(gè)postgres用戶作為數(shù)據(jù)庫的管理員,密碼隨機(jī),所以需要修改密碼,這篇文章主要給大家介紹了關(guān)于如何修改Postgresql默認(rèn)賬號postgres的密碼,需要的朋友可以參考下2023-10-10