问题描述:
有下列sql语句:
// 查找名字性别唯一的学生
select distinct name,sex from student
// 转换成MongoDB的话,需要把这种组合列去重,MongoDB好像只支持单个field的去重
db.student.distinct("name"); // 只支持一个field
db.student.distinct("name","sex"); // 错误的,不支持多个field的组合去重
目前的解决方法是通过$group实现:
1.根据id分组,id指定为组合项的话,因为id不会重复,所以作用相当于把组合项去重了。
2.假如现在需要拿出collection的其他field的话,可以使用$push关键字
// 根据name和sex分组
// 把分组后的name,sex,age放到对应的Document下,形成一个数组