Mysql 查询调优记录

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: mysql查询优化以及mysql在项目里开发遇到的问题,需要注意的地方

1、mysql会自己根据语句和数据的范围决策出使用的索引,mysql会自己使用最合适的索引,where 后面的字段顺序无需与联合索引一致。Mysql的查询优化器会使用统计数据预估使用各个索引的代价(COST),与不使用索引的代价(COST)比较。Mysql会选择代价最低的方式执行查询。

2、能建立唯一索引尽量建立unique index,这样能避免很多问题

3、不能建立类似于a_b和b_a两个索引,可能会引起死循环,需要注意

4、如果有a_b的联合索引,是不需要再单独建立一个a的索引

5、写代码的时候需要注意先explain sql语句,避免慢查询,到了千万级的数据时一个几百ms的select也能拖垮整个数据库,所以写select的时候需要注意是否使用索引

6、mysql的limit offset,limit,在offset很大时,mysql是先把offset+limit数据查询出,在取最后limit的数据,所以在进行写翻页sql时,需要注意深分页的问题,能根据自增id偏移翻页最好,如果不行的话,可以使用子查询的方式,先把自增id查出来,再根据自增id查询出你需要的字段,避免在深分页到最后取出太多的数据

7、尽量使用索引排序,如果没有任何索引能达到你想要的排序效果,尽量控制排序的数量,避免大量的数据进行filesort,实在不行,将排序在代码里进行排序,不要在大量的排序工作交给数据库,因为会拖垮数据库

8、尽量不要在mysql里使用like来进行模糊查询,首先mysql只有右模糊查询支持走索引,另外mysql模糊查询效率也比较低,可以通过elasticsearch来多条件模糊查询

9、回表去查询所需的数据意思就是你查询的字段光索引字段不够,需要根据索引查询行数据,最后再提取出你需要的字段

10、索引不是也多越好,索引多纵然提高了select的效率,但是同时降低了insert和update的效率,如果存在大量不同维度的查询,建议改走elasticsearch

11、mysql里数据类型的查询效率比varchar效率高,所以尽量不要存储字符串到数据库,枚举都转化成对应的id存储

12、代码里强制不要用select *,第一降低了查询效率,因为会返回大量无用的数据,第二也会因为增减表字段导致代码异常

13、不要向客户端返回过多的数据,数据传输可能就花费大量的时间,一般查过1000就分页查询

14、不要提交大事务,比如一次提交1000条update的事务。

15、mysql在物理硬件条件不考虑的情况下,单表能支持千万级别的数据快速读取,如果表行数到了亿级别,需要考虑是否有必要进行shading分库分表。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
6月前
|
SQL 缓存 监控
MySQL缓存机制:查询缓存与缓冲池优化
MySQL缓存机制是提升数据库性能的关键。本文深入解析了MySQL的缓存体系,包括已弃用的查询缓存和核心的InnoDB缓冲池,帮助理解缓存优化原理。通过合理配置,可显著提升数据库性能,甚至达到10倍以上的效果。
|
6月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
8月前
|
SQL 人工智能 关系型数据库
如何实现MySQL百万级数据的查询?
本文探讨了在MySQL中对百万级数据进行排序分页查询的优化策略。面对五百万条数据,传统的浅分页和深分页查询效率较低,尤其深分页因偏移量大导致性能显著下降。通过为排序字段添加索引、使用联合索引、手动回表等方法,有效提升了查询速度。最终建议根据业务需求选择合适方案:浅分页可加单列索引,深分页推荐联合索引或子查询优化,同时结合前端传递最后一条数据ID的方式实现高效翻页。
424 0
|
6月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
储存过程(Stored Procedures) 和 函数(Functions) : 储存过程和函数允许用户编写 SQL 脚本执行复杂任务.
276 14
|
6月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
以上概述了MySQL 中常见且重要 的几种 SQL 查询及其相关概念 这些知识点对任何希望有效利用 MySQL 进行数据库管理工作者都至关重要
164 15
|
6月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
6月前
|
SQL 关系型数据库 MySQL
MySQL入门指南:从安装到第一个查询
本文为MySQL数据库入门指南,内容涵盖从安装配置到基础操作与SQL语法的详细教程。文章首先介绍在Windows、macOS和Linux系统中安装MySQL的步骤,并指导进行初始配置和安全设置。随后讲解数据库和表的创建与管理,包括表结构设计、字段定义和约束设置。接着系统介绍SQL语句的基本操作,如插入、查询、更新和删除数据。此外,文章还涉及高级查询技巧,包括多表连接、聚合函数和子查询的应用。通过实战案例,帮助读者掌握复杂查询与数据修改。最后附有常见问题解答和实用技巧,如数据导入导出和常用函数使用。适合初学者快速入门MySQL数据库,助力数据库技能提升。
|
7月前
|
存储 关系型数据库 MySQL
使用命令行cmd查询MySQL表结构信息技巧分享。
掌握了这些命令和技巧,您就能快速并有效地从命令行中查询MySQL表的结构信息,进而支持数据库维护、架构审查和优化等工作。
621 9
|
6月前
|
SQL 监控 关系型数据库
MySQL高级查询技巧:子查询、联接与集合操作
本文深入解析了MySQL高级查询的核心技术,包括子查询、联接和集合操作,通过实际业务场景展示了其语法、性能差异和适用场景,并提供大量可复用的代码示例,助你从SQL新手进阶为数据操作高手。
|
8月前
|
人工智能 Java 关系型数据库
Java的时间处理与Mysql的时间查询
本文总结了Java中时间与日历的常用操作,包括时间的转换、格式化、日期加减及比较,并介绍了MySQL中按天、周、月、季度和年进行时间范围查询的方法,适用于日常开发中的时间处理需求。
150 0

推荐镜像

更多