464637258 2015-08-26 08:37 采纳率: 57.1%
浏览 4196
已采纳

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}}}
根本语法就是错的。

  • 写回答

3条回答 默认 最新

  • 464637258 2015-10-23 03:42
    关注

    已经自己解决了,查询方法出乎意料的简单。在这个例子里。直接Criteria.where("members").is(2)就行了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?