Mysql 索引优化 - 2
2024-10-19 21:52:25
永远小表驱动大表(小数据驱动大数据)
in exists区别, SELECT * FROM A WHERE A.id in (SELECT id FORM B) 若A表数据大于B表数据用in SELECT * FROM A WHERE exists (SELECT FORM B WEHRE B.id=A.id) 若A表数据小于B表数据用exists
ORDER BY使用索引
Mysql 两种排序方式: 文件排序,扫描有序索引排序
MYSQL 能为排序和查询使用相同索引
如何提高Order By的速度
Select 字段不要用Select *
增加sort_buffer_size参数
增加max_length_for_sort_data
ORDER BY 满足2个情况,会使用Index方式排序
ORDER BY 使用索引最左前列 同升同降
WHERE字句和Order by字句满足索引最左前列 如果带头是个常量,就不会
KEY a_b_c
满足下面情况产生Filesort
ORDER BY a ASC, b DESC, c DESC 排序不一致,
WHERE g = const ORDER BY b,c 丢失最左前列
WHERE a = const ORDER BY c 丢失中间b索引
WHERE a= const ORDER BY a,d排序不是索引的一部分
WHERE a in (...) ORDER BY b,c最左列不是常量
GROUP BY 和 ORDER BY 优化相同,不同的是先排序后分组
最新文章
- JavaScript 易错知识点整理
- 使用Flexible实现手淘H5页面的终端适配
- 解决:Could not parse response code.Server Reply: SSH-2.0-OpenSSH_5.3
- mysql 查看最大连接数 设置最大连接数
- 设计模式C++实现(1)——工厂模式
- IIS not allow PUT and DELETE method
- 编程器NAND Flash 技术入门
- LeetCode 238. Product of Array Except Self (去除自己的数组之积)
- Excel、Exchange 和 C# (摘要)
- css 负边距
- 【Android】用Cubism 2制作自己的Live2D——来制作动态壁纸吧!
- tomcat 8.0安装ssl证书,及centos7.2 的openssl升级到最新版本,及ERR_SSL_OBSOLETE_CIPHER错误解决
- 第一节:.Net版基于WebSocket的聊天室样例
- Java 基础 多线程进阶(锁,线程安全)
- 【MM系列】SAP 根据PO查找对应的打印FORM
- opencv学习笔记(三)
- 分享一些 Java 无关基础方面的书籍
- 压缩(zip)
- Windows 10 设置 Java 环境变量
- directive指令二 require:'^ngModel'