mongo 对数组元素查询

mongo 对数组元素查询

MongoDB中根据数组子元素进行匹配,有两种方式:
使用 “[数组名].[子元素字段名]” 的方式进行匹配。
使用 “[数组名]” $elemMatch { [子元素字段名] }的方式。

/* 1 */
{
	"_id" : "123",
	"name" : "人文医学",
	"qList" : [
		{
			"qid" : 1,
			"content" : "医学伦理学的公正原则",
			"reorderFlag" : 1
		},
		{
			"qid" : 2,
			"content" : "制定有关人体实验的基本原则",
			"reorderFlag" : 0
		}
	]
},

/* 2 */
{
	"_id" : "124",
	"name" : "人文医学2",
	"qList" : [
		{
			"qid" : 1,
			"content" : "医学伦理学的公正原则",
			"reorderFlag" : 0
		},
		{
			"qid" : 2,
			"content" : "制定有关人体实验的基本原则",
			"reorderFlag" : 1
		}
	]
}

目标:查询数组qList中qid为1,reorderFlag为0的记录
1、使用:[数组名]” $elemMatch { [子元素字段名] }的方式

db.test1.find({
    "qList"{$elemMatch: {"qid": 1, "reorderFlag": 0}}  // 同一数组内,多条件匹配,两个条件为与的关系
}) 

查询结果:

{
	"_id" : "124",
	"name" : "人文医学2",
	"qList" : [
		{
			"qid" : 1,
			"content" : "医学伦理学的公正原则",
			"reorderFlag" : 0
		},
		{
			"qid" : 2,
			"content" : "制定有关人体实验的基本原则",
			"reorderFlag" : 1
		}
	]
}

2、使用:[数组名].[子元素字段名]” 的方式

db.test1.find({
     "qList.qid": 1, "qList.reorderFlag": 0  //两个条件为或的关系
}) 

查询结果:

/* 1 */
{
	"_id" : "123",
	"name" : "人文医学",
	"qList" : [
		{
			"qid" : 1,
			"content" : "医学伦理学的公正原则",
			"reorderFlag" : 1
		},
		{
			"qid" : 2,
			"content" : "制定有关人体实验的基本原则",
			"reorderFlag" : 0
		}
	]
},

/* 2 */
{
	"_id" : "124",
	"name" : "人文医学2",
	"qList" : [
		{
			"qid" : 1,
			"content" : "医学伦理学的公正原则",
			"reorderFlag" : 0
		},
		{
			"qid" : 2,
			"content" : "制定有关人体实验的基本原则",
			"reorderFlag" : 1
		}
	]
}
MongoDB查询集合中的某个元素可以使用元素匹配(elemMatch)操作符。引用\[1\]和引用\[3\]中的代码示例展示了如何使用元素匹配进行查询。 首先,创建一个查询对象和一个条件对象。然后,使用条件对象设置筛选条件,例如使用`Criteria.where("name").is(screeningName).and("value").regex(pattern)`来匹配集合中的某个元素。接下来,将条件对象添加到查询对象中,并使用`mongoTemplate.find()`方法执行查询操作。 以下是一个示例代码,展示了如何使用元素匹配查询MongoDB集合中的某个元素: ```java Query query = new Query(); Criteria criteria = new Criteria(); criteria.and("data.list").elemMatch(Criteria.where("name").is(screeningName).and("value").regex(pattern)); query.addCriteria(criteria); List<FormDataMongoEntity> data = mongoTemplate.find(query, FormDataMongoEntity.class, "T_Cloud_Form_Data"); ``` 请注意,这只是一个示例代码,具体的查询逻辑可能需要根据你的实际需求进行调整。 引用\[2\]中的代码示例展示了如何对数进行多个条件的匹配,但是在实际情况下,这种方法只适合进行单个条件的匹配。 希望这个回答对你有帮助! #### 引用[.reference_title] - *1* *3* [mongodb文档集合中元素查询](https://blog.csdn.net/weixin_45876619/article/details/123506184)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MongoDB对数元素进行查询](https://blog.csdn.net/renfufei/article/details/78320176)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值