前言
我是MongoDB小白,剛開始學。不過,我猜大多數使用MongoDB的,都是採用對映方式處理的,即需要有定義好的用於對映的實體類。但是這樣的話,如果表的結構在未來可能頻繁變動,增刪欄位,甚至新增新的資料表。那麼這種方式就不太好用了。這時候就需要用非對映的方式處理。
對映方式操作Document
這種方式最常見,一般就是預定義一些對映的實體類,然後打上@Ducument註解。在使用MongoTemplate的查詢文件的時候,一般就是根據查詢語句建立一個Query物件,然後用MongoTemplate.find(query, entityClass)這樣的方式,就可以返回對應的實體物件集合。這樣的例子非常多,我這裡就不貼程式碼了。
非對映方式操作Document
非對映方式操作Document,就是不需要預定義實體類,也就是沒有實體類。我們只需要JSON資料就可以了。而剛好Document物件有提供toJson方法,可以返回一個JSON字串。非對映方式不能直接用MongoTemplate直接find,而是要先獲取集合物件,然後,在集合內部,相當於在表內部查詢。
例子如下:
public String findTest() { //1.獲取集合物件 MongoCollection<Document> collection = mongoTemplate.getCollection("test"); //2.建立用於查詢的BSON物件 Bson bson = eq("field", "value"); //3.利用bson條件查詢結果 FindIterable<Document> documents = collection.find(bson); //4.將結果拼接成json陣列 StringBuilder sb = new StringBuilder(); sb.append("["); for(Document document : documents) { sb.append(document.toJson() + ",\n"); } sb.append("]"); return sb.toString(); }
可用的工具包
其中,eq()方法是Mongo Spring Boot整合包提供的。它表示條件:當文件的某個欄位等於某個值的時候,文件被選中。這個方法是Filters的靜態方法,如果要直接呼叫,可以通過靜態引入:
import static com.mongodb.client.model.Filters.*;
這個類中,有很多用於過濾的方法。如eq(),ne(),gt(),lt(),in()等等更查詢條件有關的。
如果你需要用於更新的方法,那麼你可匯入Updaters的靜態方法,如set(),unSet(),rename()等等。
例子:
//注意key必須是字串,而value可以是任意型別 Bson udpateBson = set("key", "value");
以上就是把文件的某個欄位的值改為設定的值。
注:這兩個類都來自mongodb-driver-core.jar包的com.mongodb.client.model目錄下,想看更多功能可自行檢視。
如何結合查詢和更新的bson來執行一個更新操作呢?
前面的更新bson,只說明瞭怎麼更新,而沒有說明要更新誰。而一個更新操作,必然包含查詢,和修改兩個操作。那麼如何整合兩個bson來使用呢?案例如下:
//查詢條件 Bson searchBson = eq("job", "programmer"); //修改操作 Bson uddateBson = set("label", "666"); //修改所有符合條件的文件 collection.updateMany(searchBson, uddateBson);