栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用Java查询有关MongoDB中数组元素的文档

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用Java查询有关MongoDB中数组元素的文档

在这种情况下,您有一个嵌套的文档。您的文档具有一个字段

Notification
,该字段是一个数组,其中存储有多个子对象
url
。要在子字段中进行搜索,您需要使用点语法:

BasicDBObject query=new BasicDBObject("Notification.url","www.adf.com");

但是,这将返回整个文档和整个

Notification
数组。您可能只需要子文档。要对此进行过滤,您需要使用Collection.find的两个参数的版本。

BasicDBObject query=new BasicDBObject("Notification.url","www.example.com");BasicDBObject fields=new BasicDBObject("Notification.$", 1);DBCursor f = con.coll.find(query, fields);

.$
装置“这是由find-
操作者匹配这个阵列的仅第一条目”

这仍应返回一个带有子数组的文档

Notifications
,但是此数组应仅包含where项
url == "www.example.com"

要使用Java遍历此文档,请执行以下操作:

BasicDBList notifications = (BasicDBList) f.next().get("Notification"); BasicDBObject notification = (BasicDBObject) notifications.get(0);String url = notification.get("url");

顺便说一句: 当数据库增长时,除非您创建索引以加速此查询,否则您可能会遇到性能问题:

con.coll.ensureIndex(new BasicDBObject("Notification.url", 1));


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/429066.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号