开发者社区 问答 正文

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}}}
也是错的

展开
收起
小旋风柴进 2016-03-04 14:19:26 3900 分享 版权
1 条回答
写回答
取消 提交回答
  • 在这个例子里。直接Criteria.where("members").is(2)就行了

    2019-07-17 18:52:14
    赞同 展开评论