postgresql~*符號的含義及用法說明
操作符 ~~ 等效于 LIKE, 而 ~~* 對應(yīng) ILIKE。 還有 !~~ 和 !~~* 操作符 分別代表 NOT LIKE 和 NOT ILIKE。
另外:
~ 匹配正則表達式,大小寫相關(guān) 'thomas' ~ '.*thomas.*'
~*搜索 匹配正則表達式,大小寫無關(guān) 'thomas' ~* '.*Thomas.*'
!~ 不匹配正則表達式,大小寫相關(guān) 'thomas' !~ '.*Thomas.*'
!~* 不匹配正則表達式,大小寫無關(guān) 'thomas' !~* '.*vadim.*'
補充:Postgresql字符串檢索關(guān)鍵是和符號 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含義和區(qū)別
最近在做了一個關(guān)于postgreSQL相關(guān)的項目,個人工作中遇到了關(guān)于字符串檢索的一些處理,以下是個人對字符串檢索關(guān)鍵是和符號 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~*的理解,不正之處還請指出微笑
LIKE
Select * from test where varchar like ‘_a%';
varchar匹配任何a前有一個字符的字符串。
‘_'與'%'為通配符。'_'匹配任意一個字符,'%'匹配0至多個任意字符。
ESCAPE
Select* from test where varchar like ‘b_a%'escape ‘b';
varchar 匹配任何以'_a'開頭的字符串。
ESCAPE 'escape_character' 允許在字符串中搜索通配符而不是將其作為通配符使用。
請注意反斜杠在字符串文本里已經(jīng)有特殊含義了,所以如果你寫一個包含反斜杠的模式常量,那你就要在 SQL 語句里寫兩個反斜杠。
因此,寫一個匹配單個反斜杠的模式實際上要在語句里寫四個反斜杠。
你可以通過用 ESCAPE 選擇一個不同的逃逸字符來避免這樣;這樣反斜杠就不再是 LIKE 的特殊字符了。
但仍然是字符文本分析器的特殊字符,所以你還是需要兩個反斜杠。
我們也可以通過寫成 ESCAPE '' 的方式關(guān)閉逃逸機制,這時,我們就不能關(guān)閉下劃線和百分號的特殊含義。
例子:
查找數(shù)據(jù)庫中表的名字(查找以tbl_開頭的表的名字)
select tablename from pg_tables where tablename like 'tbl!_%'ESCAPE '!';
利用escape轉(zhuǎn)義: 上面的sql語句中就是將!作為轉(zhuǎn)義字符,作用是將"_"轉(zhuǎn)換成普通的"_"
ILIKE
Select * from test where varchar ilike ‘_a%';
varchar匹配任何a或者A前有一個字符的字符串。
與Like相比,ILike忽略大小寫。
正則表達式匹配操作符
~ 匹配正則表達式,大小寫相關(guān)
Select * from test where varchar ~ ‘a(chǎn)b‘;
varchar匹配任何包含'ab'的字符串。
~* 匹配正則表達式,大小寫無關(guān)
Select * from test where varchar ~‘AB‘;
varchar匹配任何包含'ab'、'aB'、'Ab'、'AB'的字符串。
與' ~'相比,忽略大小寫。
!~ 不匹配正則表達式,大小寫相關(guān)
Select * from test where varchar ~ ‘a(chǎn)‘;
varchar匹配任何不包含'a'的字符串。
!~* 不匹配正則表達式,大小寫無關(guān)
select * from test where varchar !~* ‘A‘;
varchar匹配任何不包含'a'和'A'的字符串。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL將數(shù)據(jù)加載到buffer cache中操作方法
這篇文章主要介紹了PostgreSQL將數(shù)據(jù)加載到buffer cache中,我們可以使用pg_prewarm插件來將指定的表加載到OS Buffer或者pg shared buffer中,具體操作方法跟隨小編一起看看吧2021-04-04
postgresql實現(xiàn)對已有數(shù)據(jù)表分區(qū)處理的操作詳解
這篇文章主要為大家詳細介紹了postgresql實現(xiàn)對已有數(shù)據(jù)表分區(qū)處理的操作的相關(guān)知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
PostgreSQL 實現(xiàn)sql放入文件批量執(zhí)行
這篇文章主要介紹了PostgreSQL 實現(xiàn)sql放入文件批量執(zhí)行,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
PostgreSQL數(shù)據(jù)類型格式化函數(shù)操作
這篇文章主要介紹了PostgreSQL數(shù)據(jù)類型格式化函數(shù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
PostgreSQL查詢修改max_connections(最大連接數(shù))及其它配置詳解
postgresql數(shù)據(jù)庫最大連接數(shù)是系統(tǒng)允許的最大連接數(shù),當(dāng)數(shù)據(jù)庫并發(fā)用戶超過該連接數(shù)后,會導(dǎo)致新連接無法建立或者連接超時,這篇文章主要給大家介紹了關(guān)于PostgreSQL查詢修改max_connections(最大連接數(shù))及其它配置的相關(guān)資料,需要的朋友可以參考下2024-01-01
postgresql數(shù)據(jù)合并,多條數(shù)據(jù)合并成1條的操作
這篇文章主要介紹了postgresql數(shù)據(jù)合并,多條數(shù)據(jù)合并成1條的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02
快速解決PostgreSQL中的Permission denied問題
這篇文章主要介紹了快速解決PostgreSQL中的Permission denied問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

