MongoDB 正則表達式
正則表達式是使用單個字元串來描述、匹配一系列符合某個句法規則的字元串。
許多程序設計語言都支持利用正則表達式進行字元串操作。
MongoDB 使用 $regex 操作符來設置匹配字元串的正則表達式。
MongoDB使用PCRE (Perl Compatible Regular Expression) 作為正則表達式語言。
不同於全文檢索,我們使用正則表達式不需要做任何配置。
考慮以下 posts 集合的文檔結構,該文檔包含了文章內容和標籤:
{
"post_text": "enjoy the mongodb articles on run",
"tags": [
"mongodb",
"run"
]}
使用正則表達式
以下命令使用正則表達式查找包含 runoob 字元串的文章:
>db.posts.find({post_text:{$regex:"run"}})
以上查詢也可以寫為:
>db.posts.find({post_text:/run/})
不區分大小寫的正則表達式
如果檢索需要不區分大小寫,我們可以設置 $options 為 $i。
以下命令將查找不區分大小寫的字元串 run:
>db.posts.find({post_text:{$regex:"run",$options:"$i"}})
集合中會返回所有包含字元串 runoob 的數據,且不區分大小寫:
{
"_id" : ObjectId("53493d37d852429c10000004"),
"post_text" : "hey! this is my post on runoob",
"tags" : [ "run" ]}
數組元素使用正則表達式
我們還可以在數組欄位中使用正則表達式來查找內容。 這在標籤的實現上非常有用,如果你需要查找包含以 run 開頭的標籤數據(ru 或 run 或 runoob), 你可以使用以下代碼:
>db.posts.find({tags:{$regex:"run"}})
優化正則表達式查詢
如果你的文檔中欄位設置了索引,那麼使用索引相比於正則表達式匹配查找所有的數據查詢速度更快。
如果正則表達式是前綴表達式,所有匹配的數據將以指定的前綴字元串為開始。例如: 如果正則表達式為 ^tut,查詢語句將查找以 tut 為開頭的字元串。
這裡面使用正則表達式有兩點需要注意:
正則表達式中使用變數。一定要使用eval將組合的字元串進行轉換,不能直接將字元串拼接後傳入給表達式。否則沒有報錯信息,只是結果為空!實例如下:
var name=eval("/" + 變數值key +"/i");
以下是模糊查詢包含title關鍵詞, 且不區分大小寫:
title:eval("/"+title+"/i") // 等同於 title:{$regex:title,$Option:"$i"}
TAG:程序員小新人學習 |