溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

postgresql中~*符號的作用是什么

發(fā)布時間:2021-01-29 16:02:53 來源:億速云 閱讀:330 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)postgresql中~*符號的作用是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

操作符 ~~ 等效于 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'的字符串。

看完上述內(nèi)容,你們對postgresql中~*符號的作用是什么有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI