Mysql索引性能优化问题解决方案
作者:手撕高达的村长 发布时间:2024-01-27 12:14:41
标签:Mysql,索引,性能,优化
mysql 创建的优化就是加索引,可是有时候会遇到加索引都没法达到想要的效果的情况,
加上了所以,却还是搜索的全数据,原因是sql
EXPLAIN SELECT
cs.sid,
-- c.courseFrontTitle,
-- c.imgBig,
cs.studyStatus,
coi.fee,
-- act.PROC_INST_ID_ AS processId,
cs.createDTM,
cs.payStatus,
cs.isCompleted,
cs.saleChannel,
cs.isDelete
FROM
Biz_CourseStudy cs
LEFT JOIN Biz_CourseOrderItem coi ON cs.sid = coi.CourseStudyID
WHERE
cs.studentID = 00001 and cs.payStatus not in(0)
通过看索引,原因是因为sid为bigint , CourseStudyID 的类型确实varchar,原因就是在这里,修改类型为bigint后,查询速度瞬间提升.
遇到过这样一种情况,分析extra,去掉order by 0.6s速度OK,加上order by 6s
解决方法,给order by 创建索引,这里我的order by是两个字段
order by endTime desc ,isDelete desc
为a b 创建联合索引, index_a_b
SELECT xxx FROM manage a FORCE INDEX(index_a_b)
LEFT JOIN f_name f ON f.user_id = a.user_id
ORDER BY a.endTime desc,a.isDelete desc
此时看性能,Using filesort已经消失
速度直接变成0.6s
来源:https://www.cnblogs.com/sunxun/p/12463679.html


猜你喜欢
- 本文实例讲述了Python批量重命名同一文件夹下文件的方法。分享给大家供大家参考。具体分析如下:朋友发了一个文件夹过来,里面的图片都以 .t
- 目录列表拼接三种方式方式一:简简单单的“+”方法二:切片赋值方式三:列表自带的extend()列表去重的三种方式利用集合set的特性利用字典
- PHP Date/Time 简介Date/Time 函数允许您从 PHP 脚本运行的服务器上获取日期和时间。您可以使用 Date/Time
- 有个简单的方法,使用display:table, display:table-row and display:table-cell 就可以实
- Python代码运行助手可以让你在线输入Python代码,然后通过本机运行的一个Python脚本来执行代码。原理如下:在网页输入代码:点击R
- 1 实验环境(1)服务端:本实验基于虚拟机win2008系统的WAMP环境进行,该环境相关配置过程参考文章《【语言环境】WAMP环境部署及优
- 方法一先按esc进入命令模式,即左侧线为蓝色(为绿色时是编辑模式),按z键即可恢复方法二如果是运行过的代码直接运行history方法三功能栏
- 程序用例:a=[[1,2],[4,5]]b=[0]*len(a)d=0*len(a)print("len(a)=",le
- 一、认识h函数Vue推荐在绝大数情况下使用模板来创建你的HTML,然后一些特殊的场景,你真的需要JavaScript的完全编程的能力,这个时
- 闭包是Python装饰器的基础。要理解闭包,先要了解Python中的变量作用域规则。变量作用域规则首先,在函数中是能访问全局变量的:>
- 基本上快被这个问题搞疯了,症状如下症状描述:在ie下(6或7,8没有试过)当出现中英文混排,都采用默认字体时,并使用 li 列表做float
- 方法不是主流的。有一组数据,大概10万个左右,每一单位的值不会大于30000,要求按照由大到小的顺序不重复输出。参考无忧cosin的方法后(
- file 对象使用 open 函数来创建,下表列出了 file 对象常用函数read、readline、readlines区别:1.从文件读
- 在Bootstrap的官网上,提供了一种导航栏的组件:只要在站点文件夹放好JQ与Bootstrap输入如下代码: <!DOCTYPE
- 一般来说,使用线程有两种模式, 一种是创建线程要执行的函数, 把这个函数传递进Thread对象里,让它来执行. 另一种是直接从Thread继
- 微信这个东西估计宅男没几个不熟悉的吧,微信经过这么两年多的发展终于向开放平台跨出了友好的一步。蛋疼的以为微信会出一个详细的api等接口,兴奋
- 一.Sobel算子Sobel算子是一种用于边缘检测的离散微分算子,它结合了高斯平滑和微分求导。该算子用于计算图像明暗程度近似值,根据图像边缘
- having的用法 having子句可以让我们筛选成组后的各种数据,having子句在查询过程中慢于聚合语句(sum,min,max,avg
- 什么是pyc文件pyc是一种二进制文件,是由py文件经过编译后,生成的文件,是一种byte code,py文件变成pyc文件后,加载的速度有
- 导入实验常用的python包。如图2所示。【import pandas as pd】pandas用来做数据处理。【import numpy