写服务器数据库时候有个问题。
要解决的问题是:查询某个用户所在的所有组
例如:群组的数据类型如下:
[
{"_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}}}
根本语法就是错的。