首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用Java使用正则表达式MongoDB查询字段中的值

使用Java使用正则表达式MongoDB查询字段中的值
EN

Stack Overflow用户
提问于 2018-10-17 01:01:25
回答 2查看 71关注 0票数 0

我正在尝试从我的文档集合中进行查询,如下所示:

代码语言:javascript
复制
{ "_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外壳上的对象

代码语言:javascript
复制
db.users.find(Module: {"$regex": "CE1001"}})

只需要电子邮件地址。

我试图获得所有的电子邮件地址,但卡在这个代码。

代码语言:javascript
复制
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)

EN

回答 2

Stack Overflow用户

发布于 2018-10-17 01:15:54

对于特定的Interest,您的mongoDB查询将如下所示(以CE1001为例):

代码语言:javascript
复制
db.collection.find({
  $or: [
    {
      Interests: {
        $regex: "^CE1001,"
      }
    },
    {
      Interests: {
        $regex: ",CE1001,"
      }
    },
    {
      Interests: {
        $regex: ",CE1001$"
      }
    }
  ]
},
{
  "EmailAddress": 1
})
票数 0
EN

Stack Overflow用户

发布于 2018-10-18 05:16:40

对于那些碰巧顺道来看这篇文章的人。下面是工作代码。致谢@Veeram。

代码语言:javascript
复制
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")
 }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52840565

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档