问题描述
- spring mongodb中elemMatch问题
-
写服务器数据库时候有个问题。
要解决的问题是:查询某个用户所在的所有组
例如:群组的数据类型如下:
[
{"_id":0
"members":[
1,3,4,5,6,7
]},
{"_id":1
"members":[
2,4,6,8,11,13
]},
{"_id":2
"members":[
1,7,6,4
]}
]
其中members是一个数组,包含的是每个群组成员的ID号。
现在假如我要查ID是2的用户参与的组。Criteria.where("members").elemMatch(Criteria.where("").is(2))
问题就是members这个数组,他里面的元素就是个值,也没有key,里面的criteria怎么都写不对了。
我也试过在shell里面写过类似的语句:
{ "members" : { "$elemMatch" : { "" : 2}}}
不过这是查不出结果的。或者是这么写
{ "members" : { "$elemMatch" : { 2}}}
根本语法就是错的。
解决方案
已经自己解决了,查询方法出乎意料的简单。在这个例子里。直接Criteria.where("members").is(2)就行了
解决方案二:
补充:实际写的时候ID是用ObjectId的,这里为了简化就用了INT
解决方案三:
已经自己解决了,查询方法出乎意料的简单。在这个例子里。直接Criteria.where("members").is(2)就行了
时间: 2024-07-30 12:48:09