国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數據庫 > MongoDB > 正文

通過3分鐘快速掌握MongoDB中regex的幾種用法

2020-10-29 18:44:09
字體:
來源:轉載
供稿:網友

背景

Part1:寫在最前

使用MySQL或其他關系型數據庫的朋友們都知道,使用模糊查詢的用法類似于:

SELECT * FROM products WHERE sku like "%789"; 

本文中介紹的MongoDB中的regex就是實現類似功能的,regex為能使你在查詢中使用正則表達式。本文會用簡單的實例帶您了解MongoDB中regex的用法~

Part2:用法

使用$regex時,有以下幾種用法:

{ <field>: { $regex: /pattern/, $options: '<options>' } } { <field>: { $regex: 'pattern', $options: '<options>' } } { <field>: { $regex: /pattern/<options> } } 

option參數的含義:

選項 含義 使用要求
i 大小寫不敏感
m

查詢匹配中使用了錨,例如^(代表開頭)和$(代表結尾),以及匹配/n后的字符串


x

忽視所有空白字符

要求$regex與$option合用
s 允許點字符(.)匹配所有的字符,包括換行符。 要求$regex與$option合用

實戰

Part1:$in中的用法

要在$in查詢中包含正則表達式,只能使用JavaScript正則表達式對象(即/ pattern /)。 例如:

{ name: { $in: [ /^acme/i, /^ack/ ] } } 

Warning:警告 $in中不能使用$ regex運算符表達式。

Part2:隱式and用法

要在逗號分隔的查詢條件中包含正則表達式,請使用$ regex運算符。 例如:

{ name: { $regex: /acme.*corp/i, $nin: [ 'acmeblahcorp' ] } } { name: { $regex: /acme.*corp/, $options: 'i', $nin: [ 'acmeblahcorp' ] } } { name: { $regex: 'acme.*corp', $options: 'i', $nin: [ 'acmeblahcorp' ] } } 

Part3:x和s選項

要使用x選項或s選項,要求$regex與$option合用。 例如,要指定i和s選項,必須使用$ options來執行以下操作:

{ name: { $regex: /acme.*corp/, $options: "si" } } { name: { $regex: 'acme.*corp', $options: "si" } } 

Part4:索引的使用

對于區分大小寫的正則表達式查詢,如果字段存在索引,則MongoDB將正則表達式與索引中的值進行匹配,這比全表掃描更快。如果正則表達式是“前綴表達式”,那么可以優化查詢速度,且查詢結果都會以相同的字符串開頭。

正則表達式也要符合“最左前綴原則”,例如,正則表達式/^abc.*/將通過僅匹配以abc開頭的索引值來進行優化。

Warning:警告

1.雖然/^a/,/^a.*/和/^a.*$/匹配等效字符串,但它們的性能是不一樣的。如果有對應的索引,所有這些表達式就都使用索引;不過,/^a.*/和/^a.*$/較慢。 這是因為/^a/可以在匹配前綴后停止掃描。

2.不區分大小寫的正則表達式查詢通常不能使用索引,$regex無法使用不區分大小寫的索引。

Part5:實例

一個商品的集合中,存了以下內容

{ "_id" : 100, "sku" : "abc123", "description" : "Single line description." } { "_id" : 101, "sku" : "abc789", "description" : "First line/nSecond line" } { "_id" : 102, "sku" : "xyz456", "description" : "Many spaces before line" } { "_id" : 103, "sku" : "xyz789", "description" : "Multiple/nline description" } 

如果想對該商品products集合執行一個查詢,范圍是sku列中的內容是789結尾的:

db.products.find( { sku: { $regex: /789$/ } } ) 

結合MySQL理解的話,上述查詢在MySQL中是這樣的SQL:

SELECT * FROM products WHERE sku like "%789"; 

如果想查詢sku是abc、ABC開頭的,且匹配時忽略大小寫,可以使用i選項:

db.products.find( { sku: { $regex: /^ABC/i } } )、 

查詢結果為:

{ "_id" : 100, "sku" : "abc123", "description" : "Single line description." } { "_id" : 101, "sku" : "abc789", "description" : "First line/nSecond line" } 

Part6:m的使用

想查詢描述中是包含S開頭的,且要匹配/n后的S開頭的,則需要加m選項

db.products.find( { description: { $regex: /^S/, $options: 'm' } } ) 

返回的結果是:

{ "_id" : 100, "sku" : "abc123", "description" : "Single line description." } { "_id" : 101, "sku" : "abc789", "description" : "First line/nSecond line" } 

如果不加m選項的話,返回的結果是這樣的:

{ "_id" : 100, "sku" : "abc123", "description" : "Single line description." } 

如果不使用^這類錨的話,那么會返回全部結果:

db.products.find( { description: { $regex: /S/ } } ) { "_id" : 100, "sku" : "abc123", "description" : "Single line description." } { "_id" : 101, "sku" : "abc789", "description" : "First line/nSecond line" } 

Part7:s的使用

使用s選項來執行查詢,則會讓逗號. 匹配所有字符,包括換行符,下文查詢了description列中m開頭,且后面包含line字符串的結果:

db.products.find( { description: { $regex: /m.*line/, $options: 'si' } } ) { "_id" : 102, "sku" : "xyz456", "description" : "Many spaces before line" } { "_id" : 103, "sku" : "xyz789", "description" : "Multiple/nline description" } 

如果不包含s,則會返回:

{ "_id" : 102, "sku" : "xyz456", "description" : "Many spaces before line" } 

Part8:x的使用

以下示例使用x選項忽略空格和注釋,用#表示注釋,并以匹配模式中的/ n結尾:

var pattern = "abc #category code/n123 #item number" db.products.find( { sku: { $regex: pattern, $options: "x" } } ) 

查詢的結果是:

{ "_id" : 100, "sku" : "abc123", "description" : "Single line description." } 

可以看出,其忽略了abc與#category的空格以及#category與code的空格,實際執行的查詢是sku是abc123的結果。

總結

通過這幾個案例,我們能夠了解到MongoDB中的regex用法,以及其可選參數$option每個選項的含義和用法。由于筆者的水平有限,編寫時間也很倉促,文中難免會出現一些錯誤或者不準確的地方,不妥之處懇請讀者批評指正。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
成人午夜无人区一区二区| 在线国产网址| 国产区在线看| av超碰在线| www.色婷婷| 日本中文字幕在线2020| 国产精品免费视频一区一| 97影院秋霞午夜在线观看| 亚洲综合激情六月婷婷在线观看| www.亚洲视频| 尤物网站在线| 亚洲精品少妇久久久久久| h视频在线网站| 国产蜜臀在线| av大片在线播放| 黄色片免费在线| 国产高清免费在线播放| 日p在线观看| 91欧美在线视频| 九九热在线免费视频| 国产激情视频在线| 国产鲁鲁视频在线观看免费| 精品精品导航| 国产精品免费麻豆入口| 久草.com| 女人色在线免费视频| 精精国产xxxx视频在线中文版| 日本在线天堂| 伊人免费视频| 在线观看免费高清完整| 国产系列在线观看| 天堂在线看视频| 日本中文字幕在线视频| 超碰国产在线观看| www.狠狠色.com| 日p在线观看| а√天堂8资源在线官网| 精灵使的剑舞无删减版在线观看| 国产一二三在线观看| 国产精品一区二区三区四区色| 久久99亚洲网美利坚合众国| 久热精品视频在线播放| 在线观看av网站永久| 91在线最新| av免费在线观看网站| 亚洲最新永久在线观看| 国产成人无吗| av日韩国产| 欧美性xxxx交| 国产免费电影网站入口| 尤物网址在线观看| 国产精品xxx电影| 国产福利片在线| 99在线视频影院| 免费久久网站| 中文字幕国产欧美| 精品视频一区二区观看| 亚洲男人的天堂成人| v天堂福利视频在线观看| 日本高清中文字幕| 最近中文字幕mv2018在线高清| 国产网站麻豆精品视频| 精品推荐蜜桃传媒| 青草视频在线播放| 自拍av在线| 在线免费国产视频| 国产中文在线| 精品国产美女福利到在线不卡| 青草青在线视频| 国产精品18久久久久网站| 亚洲欧美久久婷婷爱综合一区天堂| 免费看ww视频网站入口| 国产精品免费91| av中文网站| 国产高清视频在线播放| 就爱干草视频| av丝袜在线| 国产wwww| 国产一级电影网| 九九视频精品在线| 日本一卡二卡四卡精品| 伊人222成人综合网| 日本中文字幕在线播放| 欧美日韩国产亚洲沙发| 在线一区观看| 国产精品四虎| 中文字幕一区免费| 懂色av一区| 亚洲videos| 2019天天操夜夜操| 国产精品四虎| 国产精品69一区二区三区| 自拍亚洲国产| 国产私人影院| 国产精品久久久久永久免费看| 天堂在线中文资源| 国产免费一级| 国产精品臀控福利在线观看| 久久久久久久久免费视频| 超碰在线国产| 丁香花在线电影| 成年人在线观看| 狠狠干五月天| 超碰国产在线观看| 国产在线高清| 国产精品你懂的在线观看| 国产黄在线观看| 伊人狠狠av| 久久久久久91精品色婷婷| 国产麻豆精品视频一区二区| 天天操天天是| 91九色在线看| av在线不卡免费| 成年人在线观看| 国产精品jvid在线观看| 99福利在线| 国产免费电影网站入口| 国产精品久久人| 91嫩草在线播放| jizz在线免费观看| 国产免费福利网站| 国产精品久久久久一区二区国产 | 好男人社区在线视频| 国产在线精品一区二区不卡| 国产系列电影在线播放网址| 91精品专区| 超碰在线97国产| 18激情网站| 啪啪免费视频一区| 国产成人高清精品| 狠狠操狠狠色| av在线中文| 国产女主播在线| 超碰免费97在线观看| 国产黄色免费看| 国产中文字幕在线看| 影音先锋中文字幕在线| 日本中文字幕高清视频| 99久热re在线精彩视频| 日本中文字幕视频在线| 欧洲亚洲精品视频| 精品免费视频一卡2卡三卡4卡不卡 | 麻豆视频在线观看免费网站| 国产一二区在线| 九九在线观看免费视频| 亚洲xxxxxx| av手机免费在线观看| 国产精品入口麻豆高清| 久久久久久日本一区99| 日本在线视频www鲁啊鲁| 国产福利图片| 国产精品久久久久久久牛牛| 国产美女一区视频| 久久国产情侣| 久草网在线视频| 九色自拍视频| 免费a级毛片在线观看| 色欧美在线观看| 日本视频在线观看一区二区三区| 精品美女视频在线观看免费软件| 天堂亚洲精品| 中文字幕在线影院| 五月天丁香在线| 国产视频三级在线观看播放| 成视频年人免费看黄网站| 麻豆精品免费视频入口| www.中文字幕久久久| 天堂在线国产| 二区中文字幕| 1区不卡电影| 2018中文字幕在线| 99热99re6国产在线播放| 精品全国在线一区二区| 在线亚洲电影| 超碰国产在线| 中文字幕人成高视频| 国产精品入口麻豆免费看| 91精品专区| www在线观看播放免费视频日本| 狠狠干在线视频| 国产白浆在线| 青青草免费观看免费视频在线| 国产精品一区牛牛影视| 69精品视频| 国产免费麻豆视频| 精品美女视频在线观看免费软件| 伊人影院在线观看| 国产麻豆精品入口在线观看 | 国产秀色在线www免费观看| 国产黄视频网站| www.蜜桃av| 国产私拍精品| 久久久久久日本一区99| 国产porny蝌蚪视频| 青青草中文字幕| 国产成人精品综合网站| 成年网在线观看免费观看网址| 精品美女在线观看视频在线观看| 九九热视频免费观看| 国产精品四虎|