欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在php7中MongoDB實現(xiàn)模糊查詢的方法詳解

 更新時間:2017年05月03日 09:04:48   投稿:daisy  
MongoDB模糊查詢語句相信對大家來說都不陌生,這篇文章主要給大家介紹了在php 7中MongoDB實現(xiàn)模糊查詢的方法,文中給出了詳細(xì)的介紹和示例代碼,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友一起來看看吧。

前言

在實際開發(fā)中, 有不少的場景需要使用到模糊查詢, MongoDB shell 模糊查詢很簡單:

db.collection.find({'_id': /^5101/}) 

上面這句就是查詢_id以'5101'開始的內(nèi)容。

在老的MogoDB中模糊查詢挺簡單的,這里簡單記錄下模糊查詢的操作方式:

命令行下:

db.letv_logs.find({"ctime":/uname?/i});

php操作

$query=array("name"=>new MongoRegex("/.*”.$name.".*/i"));
$db->find($query);

下面主要就講下新PHP驅(qū)動中怎么查詢:

$query = new \MongoDB\Driver\Query('_id' => ['$regex' => '^5101']);
$this->getManager()->executeQuery($this->dbname . $this->collection, $query);

上面就是新驅(qū)動中執(zhí)行模糊查詢, 說實話, 挺吐槽這個新驅(qū)動, 相比老的驅(qū)動, 這個函數(shù)名也太長了吧。。。都快超過swift的函數(shù)名了。而且老驅(qū)動上的不少功能都在新驅(qū)動上干掉了。雖然提供了一個mongodb php library的類庫來操作, 但是這個庫里面有60多個文件,有時候比我項目文件還要多,這是鬧哪樣。這我建議自己去封裝一個Driver類來使用。

上面吐槽吐的有點跑題了, 除了直接模糊查詢, 在和$in$nin使用的時候, 需要特別注意下:

$filter = ['_id' => ['$in' => ['$regex' => '^5101']]];

如果你像上面那么寫filter的話, 執(zhí)行的時候?qū)伋鲆粋€致命錯誤:

PHP Fatal error: Uncaught MongoDB\Driver\Exception\ConnectionException: $in needs an array in filename

這里說$in里面需要提供一個數(shù)組, 那么我們把上面的$filter改下, 給它弄個數(shù)組過去:

$filter = ['_id' => ['$in' => [['$regex' => '^5101']]];

但是不幸的是, 還是無法成功的得到想要的結(jié)果:

PHP Fatal error: Uncaught MongoDB\Driver\Exception\ConnectionException: cannot nest $ under $in in filename

這里說$in中不能出現(xiàn)$, 那咋辦呢? 其實在$in$nin中要使用模糊匹配, 需要使用\MongoDB\BSON\Regex類的實例:

$filter = ['_id' => ['$in' => [new \MongoDB\BSON\Regex('^5101','i')]]];

這次終于得到我們想要的結(jié)果了。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論