濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > postgresql~*符號(hào)的含義及用法說(shuō)明

postgresql~*符號(hào)的含義及用法說(shuō)明

熱門(mén)標(biāo)簽:電話機(jī)器人怎么換人工座席 廣州電銷(xiāo)機(jī)器人公司招聘 地圖標(biāo)注要花多少錢(qián) 濟(jì)南外呼網(wǎng)絡(luò)電話線路 天津開(kāi)發(fā)區(qū)地圖標(biāo)注app 400電話申請(qǐng)客服 移動(dòng)外呼系統(tǒng)模擬題 電銷(xiāo)機(jī)器人能補(bǔ)救房產(chǎn)中介嗎 江蘇400電話辦理官方

操作符 ~~ 等效于 LIKE, 而 ~~* 對(duì)應(yīng) ILIKE。 還有 !~~ 和 !~~* 操作符 分別代表 NOT LIKE 和 NOT ILIKE。

另外:

~ 匹配正則表達(dá)式,大小寫(xiě)相關(guān) 'thomas' ~ '.*thomas.*'

~*搜索 匹配正則表達(dá)式,大小寫(xiě)無(wú)關(guān) 'thomas' ~* '.*Thomas.*'

!~ 不匹配正則表達(dá)式,大小寫(xiě)相關(guān) 'thomas' !~ '.*Thomas.*'

!~* 不匹配正則表達(dá)式,大小寫(xiě)無(wú)關(guān) 'thomas' !~* '.*vadim.*'

補(bǔ)充:Postgresql字符串檢索關(guān)鍵是和符號(hào) LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含義和區(qū)別

最近在做了一個(gè)關(guān)于postgreSQL相關(guān)的項(xiàng)目,個(gè)人工作中遇到了關(guān)于字符串檢索的一些處理,以下是個(gè)人對(duì)字符串檢索關(guān)鍵是和符號(hào) LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~*的理解,不正之處還請(qǐng)指出微笑

LIKE

Select * from test where varchar like ‘_a%'; 

varchar匹配任何a前有一個(gè)字符的字符串。

‘_'與'%'為通配符。'_'匹配任意一個(gè)字符,'%'匹配0至多個(gè)任意字符。

ESCAPE

Select* from test where varchar like ‘b_a%'escape ‘b'; 

varchar 匹配任何以'_a'開(kāi)頭的字符串。

ESCAPE 'escape_character' 允許在字符串中搜索通配符而不是將其作為通配符使用。

請(qǐng)注意反斜杠在字符串文本里已經(jīng)有特殊含義了,所以如果你寫(xiě)一個(gè)包含反斜杠的模式常量,那你就要在 SQL 語(yǔ)句里寫(xiě)兩個(gè)反斜杠。

因此,寫(xiě)一個(gè)匹配單個(gè)反斜杠的模式實(shí)際上要在語(yǔ)句里寫(xiě)四個(gè)反斜杠。

你可以通過(guò)用 ESCAPE 選擇一個(gè)不同的逃逸字符來(lái)避免這樣;這樣反斜杠就不再是 LIKE 的特殊字符了。

但仍然是字符文本分析器的特殊字符,所以你還是需要兩個(gè)反斜杠。

我們也可以通過(guò)寫(xiě)成 ESCAPE '' 的方式關(guān)閉逃逸機(jī)制,這時(shí),我們就不能關(guān)閉下劃線和百分號(hào)的特殊含義。

例子:

查找數(shù)據(jù)庫(kù)中表的名字(查找以tbl_開(kāi)頭的表的名字)

select tablename from pg_tables where tablename like 'tbl!_%'ESCAPE '!';

利用escape轉(zhuǎn)義: 上面的sql語(yǔ)句中就是將!作為轉(zhuǎn)義字符,作用是將"_"轉(zhuǎn)換成普通的"_"

ILIKE

Select * from test where varchar ilike ‘_a%'; 

varchar匹配任何a或者A前有一個(gè)字符的字符串。

與Like相比,ILike忽略大小寫(xiě)。

正則表達(dá)式匹配操作符

~ 匹配正則表達(dá)式,大小寫(xiě)相關(guān)

Select * from test where varchar ~ ‘a(chǎn)b‘; 

varchar匹配任何包含'ab'的字符串。

~* 匹配正則表達(dá)式,大小寫(xiě)無(wú)關(guān)

Select * from test where varchar ~‘AB‘;

varchar匹配任何包含'ab'、'aB'、'Ab'、'AB'的字符串。

與' ~'相比,忽略大小寫(xiě)。

!~ 不匹配正則表達(dá)式,大小寫(xiě)相關(guān)

Select * from test where varchar ~ ‘a(chǎn)‘; 

varchar匹配任何不包含'a'的字符串。

!~* 不匹配正則表達(dá)式,大小寫(xiě)無(wú)關(guān)

select * from test where varchar !~* ‘A‘;

varchar匹配任何不包含'a'和'A'的字符串。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 淺談PostgreSQL中大小寫(xiě)不敏感問(wèn)題
  • PostgreSQL LIKE 大小寫(xiě)實(shí)例
  • Postgresql 數(shù)據(jù)庫(kù)轉(zhuǎn)義字符操作
  • postgresql數(shù)據(jù)庫(kù)使用說(shuō)明_實(shí)現(xiàn)時(shí)間范圍查詢
  • postgresql 實(shí)現(xiàn)將數(shù)組變?yōu)樾?/li>
  • 基于PostgreSql 別名區(qū)分大小寫(xiě)的問(wèn)題

標(biāo)簽:寶雞 濮陽(yáng) 杭州 海西 昭通 榆林 溫州 辛集

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《postgresql~*符號(hào)的含義及用法說(shuō)明》,本文關(guān)鍵詞  postgresql,符,號(hào)的,含義,及,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《postgresql~*符號(hào)的含義及用法說(shuō)明》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于postgresql~*符號(hào)的含義及用法說(shuō)明的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    广东省| 大洼县| 离岛区| 闽清县| 博野县| 视频| 民丰县| 江津市| 松江区| 鹿泉市| 潞西市| 如皋市| 贵德县| 武汉市| 芒康县| 天津市| 济源市| 昌宁县| 永德县| 容城县| 广饶县| 长顺县| 平南县| 保康县| 定远县| 开鲁县| 丹凤县| 永靖县| 石渠县| 广宁县| 江山市| 乌拉特前旗| 大连市| 永胜县| 元氏县| 天峨县| 中宁县| 安丘市| 陆河县| 板桥市| 阿拉尔市|