PHP庫(kù) 查詢Mongodb中的文檔ID的方法
在IBM我的一份新工作是一名開發(fā)的后勤人員。那意味著我的大部分時(shí)間是在和數(shù)據(jù)庫(kù)打交道。在我的工作流程中,我花了一些時(shí)間在MongoDB上面——這是一個(gè)文檔數(shù)據(jù)庫(kù)。但是在通過ID來(lái)檢索記錄這個(gè)操作上面我碰到了一些問題。下面的代碼是最終版本,以后碰到類似的問題我可以直接引用它。如果大家也需要,希望下面對(duì)大家有所幫助。
MongoDB 和 IDs
當(dāng)我向一個(gè)集合中插入數(shù)據(jù)的時(shí)候,我并沒有設(shè)置_id字段;如果這個(gè)字段是空的話,那么MongoDB將要自動(dòng)生成一個(gè)ID來(lái)使用,這對(duì)我來(lái)說是非常不錯(cuò)的。然而,當(dāng)我使用MongoDB生成的標(biāo)識(shí)符的時(shí)候,這樣就會(huì)出現(xiàn)問題。
如果我使用db.posts.find()來(lái)檢索我的數(shù)據(jù)(我的集合被稱為posts),那么數(shù)據(jù)開起來(lái)如下所示:
{ "_id" : ObjectId("575038831661d710f04111c1"), ...
因此,如果我想用ID來(lái)檢索數(shù)據(jù)的話,我還需要包含ObjectId方法來(lái)訪問ID。
使用PHP庫(kù)
當(dāng)我使用PHP來(lái)做這個(gè)事情的時(shí)候,我在使用這個(gè)新的PHP類庫(kù)的時(shí)并沒有找到一個(gè)合適的例子(但是,這個(gè)類庫(kù)確實(shí)是一個(gè)非常不錯(cuò)的庫(kù))。在以前的版本中,這個(gè)庫(kù)使用一個(gè)叫做MongoID的類來(lái)實(shí)現(xiàn)。但是我知道這并不是我想要的——但是我確實(shí)可以通過這個(gè)類來(lái)檢查文檔。因此如果你僅僅能找到以前代碼中的例子,那了解這個(gè)方法還是很有用的。
通過用這個(gè)PHP庫(kù)將一個(gè)ID傳給MongoDB,你需要構(gòu)造一個(gè)MongoDB\BSON\ObjectID實(shí)例。下面的例子就是通過文檔的Id來(lái)檢索博客中的文檔。
$post = $posts->findOne(["_id" => new MongoDB\BSON\ObjectID($id)]);
然后,我將要更新這條記錄——這個(gè)博客帖子在這條記錄中還包含有嵌入的評(píng)論,因此向得到_id的這條記錄中的評(píng)論集合中添加一個(gè)數(shù)組,
$result = $posts->updateOne( ["_id" => new MongoDB\BSON\ObjectID($id)], ['$push' => [ "comments" => $new_comment_data ] ]);
最后希望本文對(duì)大家有所幫助。謝謝大家對(duì)本站的支持!
相關(guān)文章
MongoDB添加仲裁節(jié)點(diǎn)報(bào)錯(cuò):replica set IDs do not match的解決方法
這篇文章主要給大家介紹了關(guān)于MongoDB添加仲裁節(jié)點(diǎn)報(bào)錯(cuò):replica set IDs do not match的解決方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11mongoDB數(shù)據(jù)庫(kù)索引快速入門指南
索引是一種特殊的數(shù)據(jù)結(jié)構(gòu),存儲(chǔ)設(shè)置在一個(gè)易于遍歷形式的數(shù)據(jù)的一小部分。索引存儲(chǔ)一個(gè)特定的字段或一組字段的值,在索引中指定的值的字段排列的,對(duì)mongoDB索引相關(guān)知識(shí)感興趣的朋友跟隨小編一起學(xué)習(xí)下吧2022-03-03詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法
副本集是MongoDB的主從復(fù)制中的重要功能,經(jīng)常被用來(lái)作額外的備份,這里我們就來(lái)詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法,首先還是來(lái)回顧一下MongoDB中副本集的基本知識(shí):2016-07-07mongodb中使用distinct去重的簡(jiǎn)單方法
怎么在mongodb中實(shí)現(xiàn)類似于SQL中distinct的功能,查詢某一個(gè)字段所有的值,今天我們就來(lái)探討下這個(gè)問題。2015-05-05基于MongoDB數(shù)據(jù)庫(kù)的數(shù)據(jù)類型和$type操作符詳解
下面小編就為大家?guī)?lái)一篇基于MongoDB數(shù)據(jù)庫(kù)的數(shù)據(jù)類型和$type操作符詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-07-07