464637258
2015-08-26 08:37
采纳率: 57.1%
浏览 3.9k

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)就行了

    点赞 1 评论
  • 464637258 2015-10-23 03:43

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

    点赞 2 评论
  • 464637258 2015-08-26 08:41

    补充:实际写的时候ID是用ObjectId的,这里为了简化就用了INT

    点赞 评论

相关推荐 更多相似问题