【背景】
在使用MongoDB数据库时,为了减少关联操作,我们通常采用嵌套模型,数组对象是比较常见,例如商品的评论、关注好友等,通常返回前面N条或者第一条之类来减少网络流量(所有历史消息意义可能不大...).另外就是单个有16M的限制,此时可能采用连接方式,将部分信息存储在另外一个集合中。...接下来主要介绍,elemMatch,
【对比】
【相同点】
1、、elemMatch、
2、如果projection中包括其他列信息,则返回其他列+数组第一个元素.
3、都不支持用于在view上进行...filter+slice来代替,非数组条件时可以使用)
简述:都是根据条件返回数组中第一个满足条件的元素.区别在是根据查询中条件来,而elemMatch是需要显示指定一个条件,
【构造数据】
db.xiaoxu.find...在4.4之前版本中,首先返回匹配查询的结果数组中第一个元素,slice被忽略,4.4直接报错,同理从4.4开始支持在路径末尾,如果路径中间位置报错,4.4之前版本忽略
3、$slice针对数组与数组嵌套列同时出现在投影时