我正在尝试从我的文档集合中进行查询,如下所示:
{ "_id" : ObjectId("94"), "EmailAddress" :"adam@gmail.com","Interests": "CZ1001,CE2004" }
{ "_id" : ObjectId("44"), "EmailAddress" :"ben@gmail.com", "Interests":"CE1001,CE4002" }
{ "_id" : ObjectId("54"), "EmailAddress" :"chris@gmail.com","Interests":"CE1001,CE2002" }
例如,假设字段“Interest”具有我要查找的值,则我希望检索电子邮件地址。
例如,如果我搜索CZ1001,我将得到Obj 1 EmailAddress的详细信息。
如果我搜索CE1001,我将得到Obj 2和Obj 3的EmailAddress详细信息。
对象id是在我开始插入记录时唯一创建的,如果这有帮助的话。
我可以使用以下命令获取MongoDB外壳上的对象
db.users.find(Module: {"$regex": "CE1001"}})
只需要电子邮件地址。
我试图获得所有的电子邮件地址,但卡在这个代码。
Document doc = (Document) collection.find(new BasicDBObject("Module", {"$regex":"CE1001"})) .projection(Projections.fields(Projections.include("EmailAddress"), Projections.excludeId())).first();
其中不允许使用new BasicDBObject("Module", {"$regex":"CE1001"})
。
允许使用new BasicDBObject("Module", String_variable)
发布于 2018-10-17 01:15:54
对于特定的Interest
,您的mongoDB查询将如下所示(以CE1001为例):
db.collection.find({
$or: [
{
Interests: {
$regex: "^CE1001,"
}
},
{
Interests: {
$regex: ",CE1001,"
}
},
{
Interests: {
$regex: ",CE1001$"
}
}
]
},
{
"EmailAddress": 1
})
发布于 2018-10-18 05:16:40
对于那些碰巧顺道来看这篇文章的人。下面是工作代码。致谢@Veeram。
FindIterable <Document> results = collection.find(new BasicDBObject("Module", new BasicDBObject("$regex", "CE1001")) .projection(Projections.fields(Projections.include("EmailAddress"), Projections.excludeId()));
for(Document doc : results) {
doc.getString("EmailAddress")
}
https://stackoverflow.com/questions/52840565
复制相似问题