返回顶部
首页 > 资讯 > 数据库 >使用索引来排序查询结果
  • 909
分享到

使用索引来排序查询结果

2024-04-02 19:04:59 909人浏览 八月长安
摘要

使用索引来排序查询结果在mongoDB中,排序操作可以通过从索引中按照索引顺序获取文档的方式来保证结果的有序性。如果查询计划器(planner)无法从索引中得到排序顺序,那么它将需要在内存中排序结果。相比于

使用索引来排序查询结果


mongoDB中,排序操作可以通过从索引中按照索引顺序获取文档的方式来保证结果的有序性。如果查询计划器(planner)无法从索引中得到排序顺序,那么它将需要在内存中排序结果。相比于不使用索引的排序操作,使用索引会有更好的性能。此外,如果 不使用 索引的排序操作使用了超过32M的内存,那么操作会终止。


使用单键索引排序


如果一个递增或递减索引是单键索引,那么在该键上的排序操作可以是任意方向。


例如,在集合 records 的 a 键上创建递增的索引:

db.records.ensureIndex( { a: 1 } )

索引可以支持在 a 上的递增排序:

db.records.find().sort( { a: 1 } )

索引也支持如下在 a 上的递减排序,通过以相反的顺序遍历索引的方式:

db.records.find().sort( { a: -1 } )


在多个键上排序


创建 复合索引 以支持在多个键上排序。


您可以指定在索引的所有键或者部分键上排序。但是,排序键的顺序必须和它们在索引中的排列顺序 一致 。例如,索引 { a: 1, b: 1 } 可以支持排序 { a: 1, b: 1 } 但不支持 { b: 1, a: 1 } 排序。


此外,sort中指定的所有键的排序顺序(例如递增/递减)必须和索引中的对应键的排序顺序 完全相同, 或者 完全相反 。例如,索引 { a: 1, b: 1 } 可以支持排序 { a: 1, b: 1 } 和排序 { a: -1, b: -1 } ,但 不支持 排序 { a: -1, b: 1 } 。


排序与索引前缀


如果排序的键符合索引的键或者 前缀 ,那么MonGoDB可以使用索引来排序查询结果。复合索引的前缀是指被索引键的子集,由一个或多个排在最开始的键组成。


例如,在集合 data 上创建一个复合索引:

db.data.ensureIndex( { a:1, b: 1, c: 1, d: 1 } )

那么,该索引的前缀如下:

{ a: 1 }   
{ a: 1, b: 1 }    
{ a: 1, b: 1, c: 1 }

如下查询和排序操作可以使用索引前缀来排序查询结果。这些操作不需要在内存中对结果集排序。


例子      索引前缀  

db.data.find().sort( { a: 1 } )     { a: 1 }    
db.data.find().sort( { a: -1 } )     { a: 1 }    
db.data.find().sort( { a: 1, b: 1 } )     { a: 1, b: 1 }    
db.data.find().sort( { a: -1, b: -1 } )     { a: 1, b: 1 }    
db.data.find().sort( { a: 1, b: 1, c: 1 } )     { a: 1, b: 1, c: 1 }    
db.data.find( { a: { $gt: 4 } } ).sort( { a: 1, b: 1 } )     { a: 1, b: 1 }

假设有如下例子,索引的前缀键出现在查询条件和排序中:

db.data.find( { a: { $gt: 4 } } ).sort( { a: 1, b: 1 } )

在这种情况下,MongoDB可以使用索引按照sort指定的顺序来获取文档。如例子中所示,在查询条件中的索引前缀可以和在sort中出现的前缀不一样。


用非前缀的索引键排序


索引也支持使用非前缀的键来排序。在这种情况下,对于索引中排列在排序键的前面的所有键,查询语句中必须包含针对它们的 相等匹配 的条件。

例如,集合 data 有如下索引:

{ a: 1, b: 1, c: 1, d: 1 }

如下操作可以使用索引来排序:

例子      索引前缀  

db.data.find( { a: 5 } ).sort( { b: 1, c: 1 } )     { a: 1 , b: 1, c: 1 }    
db.data.find( { b: 3, a: 4 } ).sort( { c: 1 } )     { a: 1, b: 1, c: 1 }    
db.data.find( { a: 5, b: { $lt: 3} } ).sort( { b: 1 } )     { a: 1, b: 1 }

如最后一个操作所示,只有索引中那些排列在排序键 前面 的键必须在查询语句中有相等匹配条件;其他索引键则可以指定其他匹配条件。


如果查询语句 没有 对排列在排序键前面或者与之有所重叠的前缀键指定相等匹配条件,那么操作将 不会 有效使用索引。例如,如下操作指定了排序 { c: 1 } ,但是查询语句并没有对前缀键 a 和 b 指定相等匹配:

db.data.find( { a: { $gt: 2 } } ).sort( { c: 1 } )   
db.data.find( { c: 5 } ).sort( { c: 1 } )

这些操作 将不会 高效地使用索引 { a: 1, b: 1, c: 1, d: 1 } ,且可能甚至不会使用该索引来获取文档。

您可能感兴趣的文档:

--结束END--

本文标题: 使用索引来排序查询结果

本文链接: https://lsjlt.com/news/39908.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 使用索引来排序查询结果
    使用索引来排序查询结果在MongoDB中,排序操作可以通过从索引中按照索引顺序获取文档的方式来保证结果的有序性。如果查询计划器(planner)无法从索引中得到排序顺序,那么它将需要在内存中排序结果。相比于...
    99+
    2024-04-02
  • SQL查询结果数据排序(二)
    > 本节讲述 对查询结果进行排序 1 以指定的次序返回查询结果 查询 用户表中所有用户的 姓名 年龄 地区,并按照年龄的升序排列,可以使用 order by 子句 select user_name,user_age,user_pr...
    99+
    2019-11-07
    SQL查询结果数据排序(二)
  • MySQL索引查询limit offset及排序order by用法
    目录引言使用 limit 和 offset 来限制返回的数量1、limit2、offsetorder by 的如下几个用法1、order by 的升序、倒序2、多个字段排序3、按照中文排序引言 “ ...
    99+
    2023-05-20
    MySQL limit offset order by MySQL 索引查询
  • SQL 对查询结果进行排序(ORDER BY)
    目录一、ORDER BY 子句二、指定升序或降序三、指定多个排序键四、NULL 的顺序五、在排序键中使用显示用的别名六、ORDER BY 子句中可以使用的列七、不要使用列编号请参阅 学习重点 使用 ORDER BY 子句对查询结果进...
    99+
    2020-09-10
    SQL 对查询结果进行排序(ORDER BY)
  • 怎么对MySQL查询结果进行排序
    怎么对MySQL查询结果进行排序,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  MySQL查询结果如何排序  之前有一个功能...
    99+
    2024-04-02
  • MySQL怎么对查询结果进行排序
    在MySQL中,可以使用ORDER BY子句对查询结果进行排序。ORDER BY子句可以根据一个或多个列进行排序,并且还可以指定排序...
    99+
    2024-04-09
    MySQL
  • plsql查询结果排序的方法是什么
    在PL/SQL中,可以使用ORDER BY子句来对查询结果进行排序。ORDER BY子句可以跟随在SELECT语句的末尾,并...
    99+
    2024-03-14
    plsql
  • 在 MySQL 中,如何使用查询未检索到的列来指定排序顺序?
    实际上,我们知道我们可以借助 ORDER BY 子句指定排序顺序。我们需要编写 ORDER BY 关键字,后跟要对表进行排序的列的名称。我们不必在查询中的 SELECT 关键字后面使用该列名称。示例mysql> Select ...
    99+
    2023-10-22
  • Mysql如何使用索引排序
    在mysql中使用索引排序的方法首先,在命令行中启动MySQL服务;service mysql start  MySQL服务启动后,在命令行中输入mysql的用户名和密码登录到MySQL;mysql -u root -p登录到MySQL后,...
    99+
    2024-04-02
  • SQL SERVER 对检索结果排序
    1、按单列排序select 列名 from 表名 order by  列名;2、按多列排序select 列名1,列名2,列名3 from 表名 order by 列名1,列名2...
    99+
    2024-04-02
  • SQLServer中如何使用索引来提高查询性能
    在SQLServer中,可以通过以下方式来使用索引来提高查询性能: 创建索引:通过CREATE INDEX语句在表上创建索引。可以...
    99+
    2024-04-09
    SQLServer
  • mysql怎么使用索引查询
    索引在 mysql 中用于快速查找数据,通过创建索引可以显著提高查询性能。可以通过在 create table 或 alter table 语句中使用 index 或 key 子句来创建...
    99+
    2024-05-30
    mysql
  • 怎么合理的使用MySQL索引结构和查询
    这篇文章主要讲解了“怎么合理的使用MySQL索引结构和查询”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么合理的使用MySQL索引结构和查询”吧!一、高性...
    99+
    2024-04-02
  • openGemini之查询索引结构解析
    Gemini是一个开源的搜索引擎项目,它提供了一个查询索引结构,用于快速检索和提取文档数据。下面是对Gemini查询索引结构进行解析...
    99+
    2023-09-13
    openGemini
  • 如何在SQLite中使用索引来提高查询性能
    在SQLite中使用索引可以大大提高查询性能。以下是一些使用索引提高性能的方法: 创建索引:可以在需要加速的列上创建索引,通过在查...
    99+
    2024-04-09
    SQLite
  • MySQL索引查询的具体使用
    目录索引的分类聚簇索引非聚簇索引实战理解我们都知道MySQL的辅助索引可以提升检索效率,但是为什么有的时候,走辅助索引反而不如走主键索引的效率高呢?这里我觉得需要先弄懂辅助索引的底层...
    99+
    2023-05-19
    MySQL索引查询 MySQL索引
  • php如何查询出来的结果
    本教程操作环境:windows7系统、PHP8.1版、Dell G3电脑。php如何分析查询出来的结果?PHP开发中四种查询返回结果分析,需要的朋友可以参考下。1.$connection=mysql_connect("localh...
    99+
    2024-04-02
  • php怎么查询出来的结果
    本文小编为大家详细介绍“php怎么查询出来的结果”,内容详细,步骤清晰,细节处理妥当,希望这篇“php怎么查询出来的结果”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。php查询结果的方法:1、通过mysql_re...
    99+
    2023-07-04
  • 如何使用LINQ查询结果
    这篇文章主要介绍了如何使用LINQ查询结果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用LINQ查询结果如果查询结果是强类型的,如string[],List<T&g...
    99+
    2023-06-17
  • sql查询结果按条件排序的方法是什么
    在SQL中,可以使用ORDER BY子句对查询结果进行排序。ORDER BY子句可以按照一个或多个列进行排序,可以根据升序或降序排序...
    99+
    2023-09-16
    sql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作