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

ORDER BY导致未按预期使用索引

在MySQL中经常出现未按照理想情况使用索引情况,今天记录一种Order by语句使用导致未按预期使用索引情况。 1....-------------------+---------+------+--------+----------+------------------------------------+ 1.3 表索引信息如下...从SQL及索引情况来看,使用createDate字段索引应该会更好才对,为验证此情况,使用force index来强制使用createDate索引运行一次查看结果。...2 各种不太合理尝试 2.1 强制使用索引 使用force index (createDate)是可以解决,此方式上面已经测试过了 2.2 忽略不理想索引 类似于force index,可以使用...例如createDate 如果范围很大,那么其实走payDate 索引取前15条记录会更快,为了让应用改动最少且不会因为其他条件变化而导致未能走合理索引,选择另一种优化方案,将SQL改为如下情况:

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

MySQL索引优化order by与group by

MySQL索引优化order by与group by 案例一 name符合最左前缀法则,但在age处断了,所以只能用到name列,索引长度202,order by也用到了index_union索引...,再看第二张图对比下就可知,索引树是给where用, 而order by其实就是文件排序,如图三,in这三个name虽然是排好序,但age和position并不是已经排好序。...数据都在本索引树上,如果是*肯定不会有using index了,最后 就是order by文件排序了。...order by和where都需遵循最左前缀原则,类似盖楼房情景,没有一楼,不可能直接盖三楼。 利用索引覆盖减少回表 group by本质就是先排序后分组,遵循最左前缀法则。...如果分组不需要排序可以加上order by null禁止排序。 where高于having,能卸载where限定条件就不要在having限定。

56210

MySQLORDER BY field

field()函数自定义排序,格式:field(value,str1,str2,str3,str4),value与str1、str2、str3、str4比较,返回1、2、3、 4,如遇到null或者不在列表数据则返回...这个函数好像Oracle没有专门提供(也可能是我没有用到),不过自己实现这样一个函数还是比较 简单。...mysql> select * from 表名 order by field(id,4,2,3,1); +——–+——–+————+——-+ | id | name +——–+——–+————+...——-+ | 4 | | 2 | | 3 | | 1 | +——–+—— -+————+——-+ 那么它就会按照id为4,2,3,1顺序排序 根据id字段自定义排序 mysql...> select * from 表名 order by field(id,1,4,2,3) desc; +——–+——–+————+——-+ | id | name +——–+——–+————+

2.4K10

order by 字段到底要不要加索引?

本地环境试了是不生效,而且生产没那么长时间给你去试本地环境,未加order by索引全表扫描,不走索引图片加了order by 索引,索引命中,物理扫描行数急剧减少图片https://blog.csdn.net...从这个实验看,在order by字段建索引是非常划算,而且order by字段并不一定非要加入到where条件也可以生效。...如果这一列存在NULL值,NULL值是没有大小这一说法,而且不会被保存在索引。...如果优化器无法确定该列没有NULL值,为了保证结果集准确性,宁愿选择更慢全表扫描,也不会选择走可能存在NULL索引,即使用户指定了hint也不会选择百思不得其解,还是问问运维老大图片图片对于order...by字段加入索引本身这个问题,如果最终结果集是以order by字段为条件筛选,将order by字段加入索引,并放在索引中正确位置,会有明显性能提升。

10.8K20

SQLorder by高级用法

集合行之间没有预先定义顺序,它只是成员一种逻辑组合,成员之间顺序无关紧要。 如下图,每一个括号里内容就是一条记录,在没排序前,他们都是随机分布在集合。...可是当查询列发生改变,忘了修改ORDER BY列表。特别是当查询语句很长时,要找到ORDER BY与SELECT列表哪个列相对应会非常困难。...BY 城市) Customers ORDER BY ID,Name,Address 结果如下: 因为T-SQL带有ORDER BY表表达式加了TOP后返回是一个没有固定顺序表。...这里ORDER BY只对当前子查询生效,到了主查询是不起作用。必须在主查询末尾继续添加一个ORDER BY子句才能对结果集生效,就像我们例子那样。...除非逻辑要求,一般情况下并不推荐大家这样巧妙避开子查询不能使用ORDER BY限制。 以上就是有关ORDER BY一些用法,你学会了吗?有不明白或疑问地方,欢迎在底下留言。

6310

MySQL ORDER BY主键id加LIMIT限制走错索引

背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...索引查询,我们看下优化器执行过程 select product_id, sales_num, report_date from `report_product_sales_data` where...by 主键id时,limit值大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体规则究竟是怎样。...by id情况下,MySQL由于自身优化器选择,为了避免某些排序消耗,可能会走非预期PRIMARY主键索引; 对于数据量比较大,而且执行量很高分页sql,尽可能将所有的查询字段包括在索引,...同时使用索引来消除排序; 多用explain查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysqlslow_query_log,及时做排查优化。

6.5K32

MySQL ORDER BY主键id加LIMIT限制走错索引

背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...索引查询,我们看下优化器执行过程 select product_id, sales_num, report_date from `report_product_sales_data` where...by 主键id时,limit值大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体规则究竟是怎样。...by id情况下,MySQL由于自身优化器选择,为了避免某些排序消耗,可能会走非预期PRIMARY主键索引order by 和 limit 结合使用,如果where 字段,order by...字段都是索引,那么有limit索引会使用order by字段所在索引,没有limit会使用where 条件索引; 对于数据量比较大,而且执行量很高分页sql,尽可能将所有的查询字段包括在索引,同时使用索引来消除排序

1.8K10

索引b树索引

1.索引如果没有特别指明类型,一般是说b树索引,b树索引使用b树数据结构存储数据,实际上很多存储引擎使用是b+树,每一个叶子节点都包含指向下一个叶子节点指针,从而方便叶子节点范围遍历 2.底层存储引擎也可能使用不同存储结构...根据主键引用被索引行 4.b树意味着所有的值是按照顺序存储,并且每一个叶子页到根距离相同 5.b树索引能够加快访问数据速度,存储引擎不需要再进行全表扫描来获取需要数据,取而代之是从索引根节点开始进行搜索...,根节点存放了指向子节点指针,存储引擎根据这些指针向下层查找.通过比较节点页值和要查找值可以找到合适指针进入下层子节点.树深度和表大小直接相关 6.叶子节点比较特别,他们指针指向是被索引数据...,而不是其他节点页 7.b树对索引列是顺序存储,所以很适合查找范围数据. 8.索引对多个值进行排序依据是,定义索引时列顺序,比如联合索引key(a,b,c),这三个列顺序 9.上面的联合索引对以下查询语句有效...,可以用于查询order by操作,如果可以按照某种方式查到值,那么也可以按这种方式排序

1.3K20

在mysqlorder by是怎样工作

KEY `city` (`city`) ) ENGINE=InnoDB; 通过这个下面这段sql 进行排序: select city,name,age from t where city='杭州' order...by name limit 1000 ; 排序过程: 初始化一个sort buffer 我们对 city进行了索引创建所以通过索引将city为杭州筛选出来;(减少全表扫描) 将筛选出来 city...age name 字段放在内存 sortbuffer (sort buffer 为排序开辟一块新内存) 直到不符合查询条件。...(就算是limit等于1000 在这一步也会查出比1000多数据 在这块分页是不起作用 ) 一直重复第三步 将符合条件在所有数据存入 sort buffer 通过name 进行快速排序。...还有一种就是通过rowId 排序(这种情况是当一行数据过大时候) 直接上 流程图 : ?

2.3K30

Mysql索引

单列索引:索引只包含一个列。 组合索引:在多个字段上建立索引,只有在查询条件顺序使用了这些索引,索引才有效果。使用组合索引遵循最左前缀原则。...FULLTEXT(全文索引):全文索引类型为FULLTEXT,在定义索引列上支持值全文查找,允许在这些索引插入重复值和空值。...(各种函数) having select distinct order by limit 所有的查询都是从from开始,在执行过程,每个步骤都会为下一个步骤生成一个虚拟表vt1(选择相对较小表做基础表...图中每个节点称为页,页就是我们上面说磁盘块,在MySQL数据读取基本单位是页,所以我们这里叫做页更符合MySQL索引底层数据结构。...聚簇索引和非聚簇索引 在MysqlB+树索引按照存储方式不同分为聚集索引和非聚集索引

3.2K20
领券