在本文中,我們來聊聊如何在 MongoDB 中檢查一個字段是否存在。
首先,我們需要創(chuàng)建一個簡單的Mongo數(shù)據(jù)庫, 然后放入一些假數(shù)據(jù),以便在例子中使用。之后,我們將實戰(zhàn)一下如何在 Mongo 客戶端中進行查詢以及在 Java 代碼中檢查字段是否存在。
示例配置
首先,讓我們把Mongo shell上下文切換到一個存在的數(shù)據(jù)庫。
use javanorth
我們將在users
集合中插入一個用戶。
db.users.insert({name: "java", surname: "north" })
現(xiàn)在我們已經(jīng)做好了準備工作,接下去就講講如何檢查字段是否存在。
在Mongo Shell中檢查字段是否存在
我們能夠通過基本的查詢來檢查特定字段的存在與否,例如在Mongo Shell或其他數(shù)據(jù)庫控制臺。Mongo提供了一個特殊的查詢操作符,$exists
方便我們查詢驗證。
db.users.find({ 'name' : { '$exists' : true }})
我們先使用一個標(biāo)準的find
方法,在這個方法中,我們指定我們要查詢的字段,并使用$exists
查詢操作符。如果name
字段在users
集合中存在,所有包含該字段的記錄都將會被返回。
[
{
"_id": {"$oid": "6115ad91c4999031f8e6f582"},
"name": "java",
"surname": "north"
}
]
如果該字段不存在,我們將得到一個空的結(jié)果。
在Java中檢查字段的存在性
我們先添加Mongo driver 這個Maven的依賴包
< dependency >
< groupId >org.mongodb< /groupId >
< artifactId >mongo-java-driver< /artifactId >
< version >3.12.10< /version >
< /dependency >
?然后通過代碼構(gòu)建一個連接到數(shù)據(jù)庫
MongoClient mongoClient = new MongoClient();
MongoDatabase db = mongoClient.getDatabase("javanorth");
MongoCollection< Document > collection = db.getCollection("users");
使用過濾器
com.mongodb.client.model.Filters
是Mongo依賴的一個工具類,包含了很多有用的方法。我們就只需要使用exists()
方法。
Document nameDoc = collection.find(Filters.exists("name")).first();
assertNotNull(nameDoc);
assertFalse(nameDoc.isEmpty());
首先,我們嘗試從users
集合中尋找元素,并得到第一個找到的元素。如果指定的字段存在,我們得到一個nameDoc
文檔作為響應(yīng)。
現(xiàn)在,讓我們來看看當(dāng)我們試圖找到一個不存在的字段時會發(fā)生什么。
Document nameDoc = collection.find(Filters.exists("non_existing")).first();
assertNull(nameDoc);
如果沒有找到元素,我們會得到一個 null 的Document作為響應(yīng)。
使用 Document 查詢
com.mongodb.client.model.Filters
類并不是檢查字段存在的唯一方法。我們也可以使用com.mongodb.BasicDBObject:
的來查詢驗證。
Document query = new Document("name", new BasicDBObject("$exists", true));
Document doc = collection.find(query).first();
assertNotNull(doc);
assertFalse(doc.isEmpty());
結(jié)果與前面的例子相同。如果元素被找到了,我們會收到一個非null
的Document
。
當(dāng)我們試圖找一個不存在的字段時,代碼的結(jié)果也是一樣的。
Document query = new Document("non_existing", new BasicDBObject("$exists", true));
Document doc = collection.find(query).first();
assertNull(doc);
如果沒有找到任何元素,我們會得到一個null 的 Document 作為響應(yīng)。
總結(jié)
在這篇文章中,我們討論了如何在MongoDB中檢查字段是否存在。我們使用可以使用一個基本的查詢來檢查一個字段是否存在。也采用了com.mongodb.client.model.Filters
和Document
查詢方法來檢查字段的存在。
-
JAVA
+關(guān)注
關(guān)注
19文章
2946瀏覽量
104372 -
數(shù)據(jù)庫
+關(guān)注
關(guān)注
7文章
3738瀏覽量
64173 -
代碼
+關(guān)注
關(guān)注
30文章
4697瀏覽量
68086 -
Shell
+關(guān)注
關(guān)注
1文章
361瀏覽量
23234 -
mongodb
+關(guān)注
關(guān)注
0文章
22瀏覽量
357
發(fā)布評論請先 登錄
相關(guān)推薦
評論