首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql 索引排序

image.png sql 中 order by 排序可能发生2种情况: 1)对应覆盖索引,直接在索引上查询时,就是有序的,不需要另外处理排序 2)没有使用到索引,先取出数据,形成临时表做 file sort...示例目标 取出来的数据本身就是有序的,利用索引排序 示例分析 例如 有一个商品表,现在想取出某个分类下的商品,按照价格排序 sql : ... where category_id=N order...by price 目前只对分类ID做了索引,这时 order by 操作必然进行了单独的排序操作 使用 explain 分析这个sql语句时,会看到: Extra Using where;Using...filesort 改进 现在添加一个索引,category_id和price 的联合索引 再使用 explain 分析这个sql语句时,会看到: Extra Using where 可以看到没再使用filesort...,这样就利用了索引排序,因为按照索引取出来的数据本身有序,order by 操作时用到了索引,一看本身就是有序的,就不再需要file sort操作

2K60

MySQL · 最佳实践 · 如何索引JSON字段

原文地址: http://mysql.taobao.org/monthly/2017/12/09/ MySQL · 最佳实践 · 如何索引JSON字段 概述 MySQL从5.7.8起开始支持JSON字段...但MySQL并没有提供对JSON对象中的字段进行索引的功能,至少没有直接对其字段进行索引的方法。本文将介绍利用MySQL 5.7中的虚拟字段的功能来对JSON对象中的字段进行索引。...MySQL只是在数据字典里保存该字段元数据,并没有真正的存储该字段的值。这样表的大小并没有增加。我们可以利用索引把这个字段上的值进行物理存储。...在虚拟字段上加索引 再添加索引之前,让我们先看下面查询的执行计划 EXPLAIN SELECT * FROM `players` WHERE `names_virtual` = "Sally"\G  ...小结 本文介绍了如何在MySQL 5.7中保存JSON文档。为了高效的检索JSON中内容,我们可以利用5.7的虚拟字段来对JSON的不同的KEY来建索引。极大的提高检索的速度。

3.3K20
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL 支持JSON字段的基本操作、相关函数及索引使用如何索引JSON字段

具体语法规则可以参考: MySQL 5.7新增对JSON支持 https://blog.csdn.net/szxiaohe/article/details/82772881 如何索引JSON字段 MySQL...并没有提供对JSON对象中的字段进行索引的功能,我们将利用MySQL 5.7中的虚拟字段的功能来对JSON对象中的字段进行索引。...这也是MySQL默认的方式 加完虚拟列的建表语句如下,此时虚拟字段还没加索引 CREATE TABLE `t` ( `id` INT UNSIGNED NOT NULL, `js`...MySQL只是在数据字典里保存该字段元数据,并没有真正的存储该字段的值。这样表的大小并没有增加。我们可以利用索引把这个字段上的值进行物理存储。...参考:MySQL如何索引JSON字段 https://developer.aliyun.com/article/303208 MyBatis Plus查询json字段 https://blog.csdn.net

27.5K31

Mysql索引原理(八)」使用索引扫描做排序

MySQL有两种方式可以生成有序的结果:通过排序操作;或者按索引顺序扫描;如果explain出来的type列的值为index,则说明MySQL使用了索引扫描来做排序。...这基本上都是随机I/O,因此按索引顺序读取数据的速度通常要比顺序地全表扫描慢,尤其是在I/O密集型的工作负载时。 MySQL可以使用同一个索引既满足排序,又用于查找行。...只有当索引的顺序和ORDER BY子句的顺序完全一致,并且所有列的排序方向都一样时,MySQL才能使用索引结果来做排序。...如果查询需要关联多张表,则只有当ORDER BU子句引用的字段全部为第一个表时,才能使用索引排序。...ORDER BY子句和查找型查询的限制是一样的:需要满足索引的最左前缀的要求;否则,MySQL都需要执行排序操作,而无法利用索引排序

1.2K10

修改MySQL varchar类型字段排序规则

记录一个在工作中遇到的问题,也不算是问题,为的是找一种简便的方法批量修改数据表字段排序规则,在MySQL中叫collation,常常和编码CHARACTER一起出现的。...collation有三种级别,分辨是数据库级别,数据表级别和字段级别。...网上搜到的解决办法,都提到了修改数据表级别collation排序规则。...但是我遇到的场景是数据表级别已经是utf8_unicode_ci,而字段级别是utf8_general_ci,(这里我们关心的字段类型是varchar)。...由于需要修改的字段太多了,手工修改肯定是费时费力的。自然也想到了用脚本的方式批量修改,但是发现这种通过查找MySQL信息表、过滤、拼接生成批量修改的语句太好用了,而且还能做到针对varchar类型。

4.6K30

关于索引字段

关于索引字段 问题描述 关于删除字段是否适合建索引 案例重现 前段时间公司系统的一个查询接口非常缓慢,前端页面查询的时候都超时报500 了,于是去分析了sql,其实sql 很简单,就是两个表的关联查询,...settlement_list where delete_status = 1 ,速度非常慢,23s 左右,不带delete_status 也是很慢 20多s,于是看了下 settlement_list 的索引...,其他的索引都没问题,然后我就在delete_status 字段也建了个索引,建了以后再查询SELECT * FROM settlement_list where delete_status = 1...好家伙,一下就到了0.36s,这速度是一个质的飞跃啊,于是我就开始纠结了,删除字段索引,会不会被鄙视啊,理论上小基数字段不要建索引,但是实际情况,建了索引确实速度提高了啊,于是我还是提交了代码,果不其然被同事发现了...,于是开始了掰扯,把索引删掉后,速度一下又到了二十几s,加上索引速度变成1s以内,最后同事得出的结论是,确实找不到反驳的理由,加了索引速度是真的提升了,也许理论和实践还是不一样。

9920

MySQL 使用规范 —— 如何建好字段索引

这包括;库表创建规范、字段的创建规范、索引的创建规范以及SQL使用的相关规范,通过这些内容的讲解,让读者更好使用 MySQL 数据库,创建出符合规范的表和字段以及建出合适的索引。...包括;表的引擎、命名约束、字段长度、金额类型、更新时间、索引字段、组合索引等内容,方便大家学习以后,可以基于这些字段的规范演示讲解,在自己创建库表的时候有个参考对照,尽可能创建出性能更佳的库表和索引。...单表索引建议控制在5个以内,单索引字段数不超过5个。注意:已有idx(a, b)索引,又有idx(a)索引,可以把idx(a)删了,浪费空间,降低更新、写入性能。...在一些低区分度的字段,例如type、status上建立独立索引几乎没意义,降低更新、写入性能。 防止因字段不同造成的隐式转换,导致索引失效。 更新频繁的字段,不要建索引。 4....,MySQL内部需要进行特殊处理,表中有较多空字段的时候,数据库性能下降严重。

71430

Mysql索引原理(十四)」索引案例3-优化排序

在这个学习案例中,最后要介绍的是排序。使用文件排序对小数据集是很快的,但如果个查询匹配的结果有上百万行的话会怎样?例如如果 WHERE子句只有sex列,如何排序?...对于那些选择性非常低的列,可以增加一些特殊的索引来做排序。...例如,可以创建(sex,rating)索引用于下面的查询: mysql> SELECT FROM profiles WHERE sex=‘M’ ORDER BY rating LIMIT...优化这类索引的另一个比较好的策略是使用延迟关联,通过使用覆盖索引查询返回需要的主键,再根据这些主键关联原表获得需要的行。这可以减少 MySQL扫描那些需要丢弃的行数。...下面这个查询显示了如何高效地使用( sex, rating)索引进行排序和分页 mysql> SELECT FROM profiles INNER JOIN (SELECT <primary

60430

MySQL排序字段数据相同不能分页问题

MySQL排序字段数据相同不能分页问题,最近同事遇到一个列表的分页有bug,点击第1行,第2行数据会出现重复的,初步怀疑是数据重复了,通过SQL查询,确认数据都没重复。...不过分页时候会出现重复,所以怀疑是分页问题,因为我之前遇到过order by的字段有null值的情况,排序也会有问题,所以通过经验去排查排序字段数据,发现并没有null值的数据。...只是数据很多都是一样的,因为是通过批量导入的,新增时间都保存为一样的,然后分页再根据这个新增时间去排序,就会出现好像“数据重复”的现象 通过查询MySQL官方的资料,https://dev.mysql.com...大致意思是,如果order by排序字段有相同的数据,则服务器可以自由地以任何顺序返回这些行,并且可能会根据整体执行计划以不同的方式返回。...,比如批量新增时间可以加1s,避免重复 通过网上资料,还找到可以加上索引的方法处理,这个问题虽然不是自己遇到过,不过挺有意思的,所以记录起来

2.3K40

技术分享 | MySQL 可以对相同字段创建不同索引

同事问了个问题,MySQL 的某个测试库,发现有这种情况: 给已设置为主键的列又加了一次索引,如下前两条 SQL 语句。 给同一个字段加了 2 次索引,如下后两条 SQL 语句。...1测试一 数据库版本:MySQL 8.0,为表 t 设置主键,再对同字段加个索引可以执行成功。...2测试二 通过 explain,可以验证出对于同时存在 PRIMARY KEY 和普通索引字段作为检索条件时,优化器会选择 PRIMARY KEY 作为 key,这种选择应该和 MySQL索引组织表存储的形式有关...之所以存在上面的这些问题,因为 MySQL 允许创建不同名称相同索引字段索引。...Oracle 19c,在主键字段上创建索引,会提示 此列列表已索引 的错误。在相同字段上创建第二个索引,也是提示 此列列表已索引 的错误。

35040

MYSQL用法(十六) MySQL按指定字段自定义列表排序

一、 ORDER BY 排序 要求:按照字段IS_NEW_PROJ的降序、字段LOAN_APR的降序、字段GMT_BUY_START的升序排序 sql语句如下: SELECT b.PROJECT_ID...二、 ORDER BY FIELD排序(自定义排序规则) 要求:按照字段PROJECT_STATUS指定的顺序排序 sql语句如下: SELECT b.PROJECT_ID AS project_id...三、 ORDER BY FIELD排序升级(多条件组合排序) 要求:按照字段IS_NEW_PROJ降序、字段PROJECT_STATUS指定的顺序排、字段LOAN_APR降序、字段GMT_BUY_START...四、 ORDER BY 排序终极版(多条件组合排序+自定义排序) 要求:按照字段IS_NEW_PROJ降序、字段PROJECT_STATUS指定的顺序排序字段GMT_BUY_START降序、字段PROJECT_STATUS...指定的顺序排序 sql语句如下: SELECT b.PROJECT_ID AS project_id, b.PROJECT_TITLE AS project_title, b.PROJECT_STATUS

2.5K30
领券