广告
返回顶部
首页 > 资讯 > 数据库 >MySQL 查询优化
  • 557
分享到

MySQL 查询优化

2024-04-02 19:04:59 557人浏览 泡泡鱼
摘要

查询优化常用策略  1、优化数据访问:应用程序应该减少对数据库的数据访问,数据库应该减少实际扫描的记录数     例如,Redis缓存,避免"selec&#

查询优化常用策略

  1、优化数据访问:应用程序应该减少对数据库的数据访问,数据库应该减少实际扫描的记录数

     例如,Redis缓存,避免"select * from table"

  2、重写sql

     对于需要进行大量数据的操作,可以分批执行,以减少对生产系统的影响,从而缓解复制超时

Mysql join 严重降低了并发性,应该尽量连接太多的表,建议在应用层实现部分的连接功能

  3、重新设计库表

      在没有其他的优化办法下,可以考虑更改表结构设计,增加缓存表,暂存统计数据,或者增加冗余列,以减少连接

  4、索引

     索引能解决80%的问题

 

优化器介绍

  优化器的不足

   1、数据的统计信息可能是错误的

   2、CPU,内存、数据是否在缓存,都会影响优化器

   3、优化器不会考虑并发的情况,资源的郑永可能会导致性能问题

   提示:

   1、使用索引

   select * from table1 use index(col1_index,col2_index) where col1=1 and col2=2 and col3=3;

   2、不使用索引

      select * from table1 ignore index(col3_index) where col1=1 and col2=2 and col3=3;;

   3、强制使用索引

     select * from table1 force index(col3_index) where col1=1 and col2=2 and col3=3;;


    注意:use index,ignore index,force index 只会影响mysql表中检索记录和连接要使用的索引,不影响order by或group by或group by


   4、不使用查询缓存

     SQL_NO_CACHE

   5、使用查询缓存  explicit_mode,query_cache_type=2 ,指明SQL需要缓存,才缓存

    SQL_CACHE

  6 、Straight_join

     按照FROM字句描述的表的顺序进行连接

 

MySQL的连接机制

   Nested Loop join

   MySQL优化器一般会选择小表来做驱动表(外部表)


   

各种语句的优化

连接的优化

 1、连接的表不要超过4个

 2、ON,using子句的列要有索引

 3、最好能转换为inner join,left join的成本比inner join高很多

 4、explain检查连接,如果输出的rows列太高,考虑索引或连接表顺序是否不当

 5、反范式设计

 

group by、distinct、order by语句优化

1、尽量对较少的行进行排序

2、连接了多张表,order by 的列应该属于连接顺序的第一张表

3、 利用索引排序

4、group by,order by的列尽量是第一表中的列,如果不是,考虑冗余列

5、保证索引列和order by的列相同,而且按相同的方向进行排序

6、增加sort_rnd_buffer_size

7、改变tempdir变量指向基于内存的文件系统或者其他更快的磁盘

8、指定Order by null

  默认情况下MySQL将排序所有的Group by的查询,如果要避免排序结果,可以指定Order by null;

9、优化Group by with rollup

   考虑在应用层实现

10、使用非group by的列来替代group by的列

   比如 group by x,y,如果group by z 能到到相同的结果,则尽量少出现group by

11、考虑用Sphinx替代 group by语句



优化子查询

   大多数情况下,连接会比子查询快,子查询生成的临时表没有索引

   

   select distinct col1 from t1 where col1 in (select col1 from t2);

   改写为:

   select distinct t1.col1 from t1,t2 where t1.col1=t2.col1;

   

select * from t1 where id not in (select id from t2);


改写:

select * from t1 where not exists (select id from t2 where t1.id=t2.id) 

也可以改写为:

select table1.* from table1 left join table2 on table1.id=table2.id where table2.id is null;



把子句从子查询的外部转移到内部


select * from t1 where s1 in (select s1 from t1) or s1 in (select s1 from t2);

改写

select * from t1 where s1 in (select s1 from t1 uNIOn all select s1 from s2);



select (select column1 from t1) +5 from t2;

改写

select (select column1+5 from t1) from t2;








  

   


优化limit字句


优化 IN


优化Union


优化带有BLOB、Text类型字段的查询

filesort的优化


优化SQL_CALC_FOUND_ROWS

优化临时表



OLAP业务优化





您可能感兴趣的文档:

--结束END--

本文标题: MySQL 查询优化

本文链接: https://www.lsjlt.com/news/43457.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql优化——查询优化
    这一篇mysql优化是注重于查询优化,根据mysql的执行情况,判断mysql什么时候需要优化,关于数据库开始阶段的数据库逻辑、物理结构的设计结构优化不是本文重点,下次再谈。 查看mysql语句的执行情况,判断是否需要进行优化 ...
    99+
    2016-09-05
    mysql优化——查询优化
  • mysql查询优化
    select * from a where id in (select id from b) 等价于: for select id from b for select 8 from...
    99+
    2022-02-02
    mysql查询优化
  • MySQL 查询优化
    查询优化常用策略  1、优化数据访问:应用程序应该减少对数据库的数据访问,数据库应该减少实际扫描的记录数     例如,Redis缓存,避免"selec&#...
    99+
    2022-10-18
  • 如何优化MySQL查询
    这篇文章给大家介绍如何优化MySQL查询,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。解析器和预处理器一开始,MySQL 的解析器将查询语句拆分成一系列指令并从中构建一棵“解析树”。解析器使用 MySQL 的SQL 语...
    99+
    2023-06-15
  • mysql in慢查询优化
    目录记一次mysql慢查询优化——生产环境待办列表现场演示5~6s才加载出来结果;顿时,产品经理的脸挂不住了,作为多年经验的老开发,心想完犊子,脸啪啪滴。 不过,秉着多年的江湖经验,遇事不慌,拍个...
    99+
    2023-05-12
    mysql in慢查询优化 mysql in慢查询优化
  • mysql查询语句优化
     这篇说下mysql查询语句优化 是否请求了不需要的数据 典型案例:查询不需要的记录,多表关联时返回全部列,总是取出全部列,重复查询相同的数据。 是否在扫描额外的记录 ...
    99+
    2022-05-11
    mysql
  • mysql-查询性能优化
    不要取出全部列,取出全部列,会让优化器无法完成索引覆盖扫描这类优化,还会为服务器带来额外的I/O、内存和CPU的消耗。应该严格禁止SELECT * 的写法。MySQL使用如下三种方式应用WHERE条件,从好到坏依次...
    99+
    2021-02-18
    mysql-查询性能优化
  • PHP与MySQL查询优化
    随着互联网和信息技术的发展,Web应用程序成为了企业和个人必备的一项技术。在Web应用程序中,PHP与MySQL是相当重要的技术,PHP提供了丰富的功能和特性,而MySQL则是用于存储和管理数据。然而,当数据量增加时,查询操作的性能问题变得...
    99+
    2023-05-18
    MySQL PHP 查询优化
  • Mysql查询优化之IN子查询优化方法详解
    目录物化表物化表转连接总结物化表 首先提出一个不相关的IN子查询 SELECT * FROM s1 WHERE key1 IN (SELECT commo...
    99+
    2023-02-09
    mysql in子查询优化 mysql in语句优化 mysql查询效率优化
  • MySQL 如何优化慢查询?
    一、前言 在日常开发中,我们往往会给表加各种索引,来提高 MySQL 的检索效率。 但我们有时会遇到明明给字段加了索引,并没有走索引的Case。 进而导致 MySQL 产生慢查询。 严重场景下,甚至出现主从延迟、数据库拖垮的极端事故。 本文...
    99+
    2023-10-08
    mysql 数据库 java
  • MySQL查询优化临时表
    【理论分析】 MySQL在执行SQL查询时可能会用到临时表,一般情况下,用到临时表就意味着性能较低。 临时表存储 MySQL临时表分为“内存临时表”和“磁盘临时表”,其中内存临时表使用MySQL的MEMORY存储引擎,磁盘临时表使用MySQ...
    99+
    2019-09-24
    MySQL查询优化临时表
  • MySQL优化(4):查询缓存
    查询缓存: MySQL提供的数据缓存QueryCache,用于缓存SELECT查询的结果 默认不开启,需要在配置文件中开启缓存(my.ini/my.cnf) 在[mysqld]段中,修改query_cache_type完成...
    99+
    2018-07-13
    MySQL优化(4):查询缓存
  • MySQL,优化查询的方法
    对于数据库,优化查询的方法 1.使用索引   使用索引时,应尽量避免全表扫描,首先应考虑在 where 及 order by ,group by 涉及的列上建立索引。 2.优化SQL语句  1)分析查询语句:通过对查询语...
    99+
    2017-10-28
    MySQL,优化查询的方法
  • MySQL查询优化利刃-EXPLAIN
    有一个 遇到这样一个疑问:当where查询中In一个索引字段作为条件,那么在查询中还会使用到索引吗? SELECT * FROM table_name WHERE column_index in (ex...
    99+
    2019-04-17
    MySQL查询优化利刃-EXPLAIN
  • MYSQL(四)查询性能优化
    优化数据访问1.是否向数据库请求了不需要的数据解决方式:A. 查询后加limitB. Select后写需要的列而不是*2. 是否扫描了额外的数据数据库的访问方式速度由...
    99+
    2022-10-18
  • MySQL的查询优化方法
    本篇内容主要讲解“MySQL的查询优化方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL的查询优化方法”吧!1、简介    &nb...
    99+
    2022-10-18
  • MySQL查询优化的方式
    本篇内容介绍了“MySQL查询优化的方式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 在分析查询性能时...
    99+
    2022-10-18
  • MySQL查询优化的简介
    这篇文章给大家分享的是有关MySQL查询优化的简介的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言MySQL是关系性数据库中的一种,查询功能强,数据一致性高,数据安全性高,支持...
    99+
    2022-10-18
  • MySQL优化 - 性能分析与查询优化
    MySQL优化 - 性能分析与查询优化    优化应贯穿整个产品开发周期中,比如编写复杂SQL时查看执行计划,安装MySQL服务器时尽量合理配置(见过太多完全使用默认配置安装的情况),根...
    99+
    2022-10-18
  • 怎么在mysql中优化查询
    这篇文章给大家介绍怎么在mysql中优化查询,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、减少请求的数据量。只回到必要的列:最好不要使用SELECT*语言。只返回必要的行:使用LIMIT语言限制返回的数据。缓存重复...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作