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> ...
随机推荐
- 8-STM32物联网开发WIFI(ESP8266)+GPRS(Air202)系统方案安全篇(Apache 配置SSL,HTTPS连接)
https://www.cnblogs.com/yangfengwu/p/10947423.html 和当时配置MQTT差不多,去下载证书文件 https://www.cnblogs.com/ya ...
- Python——IO多路复用之select模块epoll方法
Python——IO多路复用之select模块epoll方法 使用epoll方法实现IO多路复用,使用方法基本与poll方法一致,epoll效率要高于select和poll. .├── epoll_c ...
- mysql 8创建远程访问用户以及连接mysql速度慢的解决方法
mysql 8创建远程访问用户 [root@demo /]# mysql -u root -p #登录服务器数据库 Enter password:123xxx >user mysql; & ...
- RE:SB的SDOISB记
Day0 到了农大 进门看见hly 和myj一起乱%一通 一本爷的气场就是强大 晚上gryz搬砖三人组出去吃饭,开心>_< 吃完饭后去试机 手速比较快,写了一下ntt,lct,sa和一些小 ...
- db服务器参数优化
1.swap分区 swap作用是在系统内存不够的情况下,当做临时的内存使用. swap是在硬盘上,性能肯定没有再内存好,当系统内存使用超过40%的时候, swap会可能被使用,而系统一旦使用swap会 ...
- NET Core3前后端分离开发框架
NET Core前后端分离快速开发框架 https://www.cnblogs.com/coldairarrow/p/11870993.html 引言 时间真快,转眼今年又要过去了.回想今年,依次开源 ...
- PatchMatchStereo可能会需要的Rectification
在稠密三维重建中,rectification可以简化patch match的过程.在双目特征匹配等场景中其实也用得到,看了一下一篇论文叫< A Compact Algorithm for Rec ...
- 词向量实践(gensim)
词向量训练步骤: 分词并去停用词 词频过滤 训练 项目完整地址:https://github.com/cyandn/practice/tree/master/Word2Vec gensim中Word2 ...
- Git flow 工作流与规范
概述 简版图: PS. 可能用到的命令: 1.从指定 commit拉出新分支 git checkout commitId -b 本地新branchName git checkout 9fbc3d0 ...
- Golang 调用 C/C++,例子式教程
大部分人学习或者使用某样东西,喜欢在直观上看到动手后的结果,才会有继续下去的兴趣. 前言: Golang 调用 C/C++ 的教程网上很多,就我目前所看到的,个人见解就是比较乱,坑也很多.希望本文能在 ...