mongodb 通过嵌入文档中的字段排序
mongodb中的全部数据:
db.testInfo.find({})
.sort({_id:-1})
.limit(100)
查询结果:
/* 1 createdAt:2019/10/11 下午5:12:50*/
{
"_id" : ObjectId("5da04792665cd81dc0d46d3d"),
"name" : "jim2",
"age" : 5,
"list" : [
{
"title" : "a2",
"price" : 1
},
{
"title" : "a1",
"price" : 5
}
]
}, /* 2 createdAt:2019/10/11 下午5:01:55*/
{
"_id" : ObjectId("5da04503665cd81dc0d46d3c"),
"name" : "leo",
"age" : 4,
"list" : [
{
"title" : "a1",
"price" : 3
},
{
"title" : "d2",
"price" : 2
}
]
}, /* 3 createdAt:2019/10/11 下午5:01:55*/
{
"_id" : ObjectId("5da04503665cd81dc0d46d3b"),
"name" : "jason",
"age" : 3,
"list" : [
{
"title" : "a1",
"price" : 2
},
{
"title" : "c2",
"price" : 1
}
]
}, /* 4 createdAt:2019/10/11 下午5:01:55*/
{
"_id" : ObjectId("5da04503665cd81dc0d46d3a"),
"name" : "mark",
"age" : 2,
"list" : [
{
"title" : "a1",
"price" : 3
},
{
"title" : "b2",
"price" : 4
}
]
}, /* 5 createdAt:2019/10/11 下午5:00:12*/
{
"_id" : ObjectId("5da0449c665cd81dc0d46d39"),
"name" : "jim",
"age" : 1,
"list" : [
{
"title" : "a1",
"price" : 1
},
{
"title" : "a2",
"price" : 2
}
]
}
通过嵌入文档中查询指定title的数据,然后根据price排序,注意需要排序时将查询的title也一并作为排序字段,否则顺序会错乱。
db.testInfo.find({"list.title":"a1"})
.sort({
"list.title":1,
"list.price":1
});
查询结果:
/* 1 createdAt:2019/10/11 下午5:00:12*/
{
"_id" : ObjectId("5da0449c665cd81dc0d46d39"),
"name" : "jim",
"age" : 1,
"list" : [
{
"title" : "a1",
"price" : 1
},
{
"title" : "a2",
"price" : 2
}
]
}, /* 2 createdAt:2019/10/11 下午5:01:55*/
{
"_id" : ObjectId("5da04503665cd81dc0d46d3b"),
"name" : "jason",
"age" : 3,
"list" : [
{
"title" : "a1",
"price" : 2
},
{
"title" : "c2",
"price" : 1
}
]
}, /* 3 createdAt:2019/10/11 下午5:01:55*/
{
"_id" : ObjectId("5da04503665cd81dc0d46d3a"),
"name" : "mark",
"age" : 2,
"list" : [
{
"title" : "a1",
"price" : 3
},
{
"title" : "b2",
"price" : 4
}
]
}, /* 4 createdAt:2019/10/11 下午5:01:55*/
{
"_id" : ObjectId("5da04503665cd81dc0d46d3c"),
"name" : "leo",
"age" : 4,
"list" : [
{
"title" : "a1",
"price" : 3
},
{
"title" : "d2",
"price" : 2
}
]
}, /* 5 createdAt:2019/10/11 下午5:12:50*/
{
"_id" : ObjectId("5da04792665cd81dc0d46d3d"),
"name" : "jim2",
"age" : 5,
"list" : [
{
"title" : "a2",
"price" : 1
},
{
"title" : "a1",
"price" : 5
}
]
}
目前好像根据经纬度范围查询时,无法同时指定嵌入文档中的字段正确排序。只能先通过经纬度范围查询出来所有数据后,再根据嵌入文档中字段进行排序。
特殊情况下是否可以考虑固定嵌入集合数量,指定下标来对应字段排序(未测试过)。
学艺不精,如有其他办法,欢迎留言一起讨论。
mongodb 通过嵌入文档中的字段排序的更多相关文章
- winform 替换word文档中的字段(包含图片添加),生成导出PDF文件(也可是word文件)
1.先打开你需要替换的word文档,在想要后续更换字段值的地方添加“书签”. 2.将模板文档存放在 程序的Debug文件下. 3.生成文件的按钮点击事件 代码: string templatePath ...
- 利用python处理文档中各字段出现的次数并排序
import string path = 'waldnn' with open(path,'r') as text: words = [raw_word.strip(string.punctuatio ...
- MongoDB(12)- 查询嵌入文档的数组
插入测试数据 db.inventory.insertMany( [ { item: "journal", instock: [ { warehouse: "A" ...
- 01将图片嵌入到Markdown文档中
将图片内嵌入Markdown文档中 将图片嵌入Markdown文档中一直是一个比较麻烦的事情.通常的做法是将图片存入本地某个路径或者网络存储空间,使用URL链接的形式插入图片: ![image][ur ...
- Mongodb:修改文档结构后出现错误:Element '***' does not match any field or property of class ***.
Mongodb:修改文档结构后出现错误:Element '***' does not match any field or property of class ***. Mongodb是一种面向文档的 ...
- shell之实战应用一(查找xml文档中的关键字段)
前几天同事问我一个问题,说如下的文档中,如何把name后面的字段(红色框中的字段)单独打印出来?
- MongoDB .Net Driver(C#驱动) - 内嵌数组/嵌入文档的操作(增加、删除、修改、查询(Linq 分页))
目录 一.前言 1. 运行环境 二.前期准备工作 1. 创建 MongoDBContext MongoDb操作上下文类 2.创建测试类 3.创建测试代码 三.内嵌数组增加元素操作 1.Update.S ...
- MongoDB 内嵌文档
MongoDB是文档型的数据库系统,doc是MongoDB的数据单位,每个doc相当于关系型数据库的数据行(row),doc和row的区别在于field的原子性:row中的column是不和分割的原子 ...
- MongoDB学习笔记——文档操作之查询
查询文档 使用db.COLLECTION_NAME.findOne()可以查询所有满足条件的第一条数据 预发格式如下: db.COLLECTION_NAME.findOne(<query> ...
随机推荐
- 网络协议 16 - DNS 协议
为什么在地址栏输入域名,就能直接访问到对应服务器?全局负载均衡和内部负载均衡又是什么?这些都和 DNS 解析息息相关,让我们一起来解密 DNS 解析. 其实说起 DNS 解析,应该都知道它很像 ...
- 洛谷 P4427
传送门 洛谷P4427 题意: 给你一个数,然后让你求这两个数之间的点的深度的k次方和. #思路: 很容易想到lca.因为lca可以说是求树上两个点的距离的好方法.而且lca还能遍历每一个点. 然后我 ...
- 【CSP-S膜你考】不怕噩梦 (模拟)
不怕噩梦 题面 蚊子最近经常做噩梦,然后就会被吓醒.这可不好.. 疯子一直在发愁,然后突然有一天,他发现蚊子其实就是害怕某些事. 如果那些事出现在她的梦里,就会害怕. 我们可以假定那个害怕的事其实是一 ...
- PATA1005Spell It Right
考虑输入为0的特殊情况 参考代码: #define _CRT_SECURE_NO_WARNINGS #include<cstdio> #include<cstring> #in ...
- 绘制matplotlib 饼状图
参考:https://blog.csdn.net/ScarlettYellow/article/details/80458797 (2)2016年就业人员在三次产业中分布的饼状图. def swap( ...
- Android Studio 之 ROM【3】,LiveData+ViewModel+AsyncTask+Repository+RecyclerView
教程地址:https://www.bilibili.com/video/av65180549 源码地址:https://github.com/longway777/Android-2019-Tutor ...
- 【Gamma阶段】第十次Scrum Meeting
[Gamma阶段]第十次Scrum Meeting 每日任务内容 今日工作任务 明日待完成任务 完成人 准备测试质量保证的展示材料 准备测试展示视频 赵智源 修复热评的子评论BUG 准备前端技术展示材 ...
- docker 学习操作记录 5
记录5 * Overheard at KubeCon: "microk8s.status just blew my mind". https://microk8s.io/docs/ ...
- Visual Studio 调试 —— 附加到进程
第一步:通过管理员方式打开想要附加到进程的项目. 第二步:在 “附加到进程” 对话框中的 “可用进程” 列表中,找到要附加到的程序.我的以 MyProgressTest 为例.选择调试 / 附加到进程 ...
- [转帖]spring boot项目集成jacoco
小试牛刀:spring boot项目集成jacoco 2019-03-28 20:14:36 zyq23333 阅读数 509 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议, ...