开发者社区> 问答> 正文

MongoDB 查询字段是列表,如何只取列表符合条件的字段输出

假如数据库中记录是下面4条:
`{
code: "1",
qty: [
{ size: "a", num: 10, color: "blue" },
{ size: "b", num: 100, color: "blue" },
{ size: "c", num: 100, color: "blue" },
] },
{
code: "2",
qty: [
{ size: "a", num: 10, color: "blue" },
{ size: "e", num: 100, color: "blue" },
{ size: "f", num: 100, color: "blue" },
] },
{
code: "3",
qty: [
{ size: "h", num: 10, color: "blue" },
{ size: "b", num: 100, color: "blue" },
{ size: "i", num: 100, color: "blue" },
] },
{
code: "4",
qty: [
{ size: "j", num: 10, color: "blue" },
{ size: "k", num: 100, color: "blue" },
{ size: "m", num: 100, color: "blue" },
]
} `
想要查询qty字段对应列表中包含size:“a” 或者包含size:“b” 的结果 期望返回结果是:
`{
code: "1",
qty: [
{ size: "a", num: 10, color: "blue" },
{ size: "b", num: 100, color: "blue" },
] },
{
code: "2",
qty: [
{ size: "a", num: 10, color: "blue" },
] },
{
code: "3",
qty: [
{ size: "b", num: 10, color: "blue" },
] },`
请问大神 mongodb如何实现?

展开
收起
落地花开啦 2016-02-21 15:38:11 3383 0
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    qty: [ { size: "a", num: 10, color: "blue" }, ] 是数组,属于一个字段. 你的想法用简单的查询无法实现. 数据量不大可以使用MapReduce.

    2019-07-17 18:46:01
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Data as a Service - 数据即服务 -- MongoDB⾼级应⽤模式 立即下载
MongoDB多数据中心的方案选型之路 立即下载
饿了么高级架构师陈东明:MongoDB是如何逐步提高可靠性的 立即下载

相关镜像