热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MYSQL数据库优化的方式分享

本篇内容主要讲解“MYSQL数据库优化的方式分享”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MYS

本篇内容主要讲解“MYSQL数据库优化的方式分享”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MYSQL数据库优化的方式分享”吧!

如果在一个系统中,用户反映系统太卡,那么我们可以怎么进行优化呢?

  1. 如果http请求过多,则可以认定是web服务器承受的压力过大,可以增加web服务器,做负载均衡进行优化。

  2. 如果我们访问静态界面不卡顿,但是申请动态数据的时候发生卡顿,说明我们数据库所处理的请求过多,这时候有大量的查询压力到数据库,这时候就需要考虑数据库的优化了。


要想知道我们数据库优化究竟在做一些什么事情,首先我们需要了解MYSQL的执行过程。

MYSQL数据库优化的方式分享

图源自网络,如有侵权请联系删除。

mysql执行过程

  1. 当我们请求连接mysql服务器时,mysql会对请求有一个监听,当我们发起的请求到达以后,服务器得到我们需要执行的SQL语句,这时我们的SQL语句就进入MYSQL的内部。

  2. MYSQL会首先查询缓存,看这个SQL语句是否执行过,如果我们执行过这个SQL语句,则把缓存中的执行结果返回,但是在MYSQL中,这个查询缓存默认是不开启的,因为查询缓存要求SQL语句和参数都要一样,所以基本上缓存中的数据我们都命中不了。

  3. 如果我们没有开启查询缓存,或者查询缓存却没有找到对应的结果,这时候SQL语句就传到了解析器中。解析器会对要执行的SQL语句进行解析,然后SQL语句就变成一颗解析树,这时候解析树不能马上就执行,还需要对解析树进行预处理,预处理的目的在于规定常量的存储位置,计算表达式并返回结果等。

  4. 预处理结束后,此时这棵树就是要进行执行的树,在和初始的解析树对比,这棵树得到了一些优化。


MYSQL数据库里面最关键的知识点,就是查询优化器。比如我们写这么一条SQL语句:SELECT  *  FROM  BOOK  WHERE  BOOKNAME = 'BODY'  AND  PRICE  =  56,只是SQL语句会怎么去进行执行呢?它会先执行BOOKNAME = 'BODY'还是 PRICE  =  56呢?SQL语句的执行顺序就是根据数据库对数据统计表的一些信息,比如索引或者表中一共有多少行数据,MYSQL数据库都是会进行缓存的,这时查询优化器就会根据这些数据进行一个判定,判断这一个SQL语句的执行过程中到底选择哪种执行方式,运行结果可能更快。所以说这一步操作其实是MYSQL性能中最关键的核心,这也是我们优化所需要遵循的原则。

所以说我们平常所说的优化SQL,其实就是想让查询优化器能按照我们的想法,选择最佳的执行方案,因为我们更清楚的知道我们的数据,而MYSQL看到的数据仅仅是自己收集到缓存的那一部分信息,而这些信息的正确性不能得以保证,MYSQL根据它收集到的信息选择一个它认为最佳的执行方案,但是这个方案很有可能和我们想要它执行的方案不一致。

这里说到的选择执行方案,其实就是刚才举例所讲的先执行BOOKNAME = 'BODY'还是 PRICE  =  56,这个执行方案会传给查询执行引擎,引擎会去执行这一份接收到的执行方案。这个时候有一个很重要的问题:影响这个查询性能的最关键原因是什么呢?其实就是我们最常讲到的IO,一条SQL语句执行的时间,就是由这个时间段的IO来决定的。而执行IO又是由数据库传过去的这个执行方案来决定的。如果我们开启了查询缓存,则在将结果返回给客户端之前,也会将执行结果存放到查询缓存中,下一次进行该查询会直接在查询缓存中返回执行结果。

到此,相信大家对“MYSQL数据库优化的方式分享”有了更深的了解,不妨来实际操作一番吧!这里是编程笔记网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


推荐阅读
  • 如何优化MySQL数据库性能以提升查询效率和系统稳定性 ... [详细]
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • php更新数据库字段的函数是,php更新数据库字段的函数是 ... [详细]
  • 本文详细介绍了MySQL数据库的基础语法与核心操作,涵盖从基础概念到具体应用的多个方面。首先,文章从基础知识入手,逐步深入到创建和修改数据表的操作。接着,详细讲解了如何进行数据的插入、更新与删除。在查询部分,不仅介绍了DISTINCT和LIMIT的使用方法,还探讨了排序、过滤和通配符的应用。此外,文章还涵盖了计算字段以及多种函数的使用,包括文本处理、日期和时间处理及数值处理等。通过这些内容,读者可以全面掌握MySQL数据库的核心操作技巧。 ... [详细]
  • 通过使用Sqoop导入工具,可以精确控制并高效地将表数据的特定子集导入到HDFS中。具体而言,可以通过在导入命令中添加WHERE子句来指定所需的数据范围,从而在数据库服务器上执行相应的SQL查询,并将查询结果高效地存储到HDFS中。这种方法不仅提高了数据导入的灵活性,还确保了数据的准确性和完整性。 ... [详细]
  • 本文详细介绍了在MySQL中如何高效利用EXPLAIN命令进行查询优化。通过实例解析和步骤说明,文章旨在帮助读者深入理解EXPLAIN命令的工作原理及其在性能调优中的应用,内容通俗易懂且结构清晰,适合各水平的数据库管理员和技术人员参考学习。 ... [详细]
  • 黄聪:MySQL主从复制配置,实现高效读写分离
    大型网站为应对高并发访问,不仅需要在前端实现分布式负载均衡,还需在数据业务和访问层采取有效措施。采用传统的数据结构已无法满足需求,通过配置MySQL主从复制,可实现高效的读写分离,显著提升系统性能和稳定性。 ... [详细]
  • SQL 连接详解与应用
    本文详细介绍了 SQL 连接的概念、分类及实际应用,包括内连接、外连接、自连接等,并提供了丰富的示例代码。 ... [详细]
  • 在使用达梦数据库时,管理员可能会遇到连接频繁中断或特定SQL语句语法错误的问题。这些问题通常源于开发人员在创建对象时的不规范操作。为了解决这些问题,建议对数据库配置进行优化,并确保所有SQL语句符合达梦数据库的标准语法。此外,定期检查和维护数据库连接参数,以及对异常日志进行详细分析,也有助于及时发现并解决问题。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 第二章:Kafka基础入门与核心概念解析
    本章节主要介绍了Kafka的基本概念及其核心特性。Kafka是一种分布式消息发布和订阅系统,以其卓越的性能和高吞吐量而著称。最初,Kafka被设计用于LinkedIn的活动流和运营数据处理,旨在高效地管理和传输大规模的数据流。这些数据主要包括用户活动记录、系统日志和其他实时信息。通过深入解析Kafka的设计原理和应用场景,读者将能够更好地理解其在现代大数据架构中的重要地位。 ... [详细]
  • 期末Web开发综合实践项目:运用前端技术打造趣味小游戏体验
    期末Web开发综合实践项目中,学生通过运用HTML、CSS和JavaScript等前端技术,设计并实现了一款趣味性十足的小游戏。该项目不仅检验了学生对前端基础知识的掌握情况,还提升了他们的实际操作能力和创意设计水平。视频链接展示了项目的最终成果,直观呈现了游戏的互动性和视觉效果。 ... [详细]
  • 负载均衡基础概念与技术解析
    随着互联网应用的不断扩展,用户流量激增,业务复杂度显著提升,单一服务器已难以应对日益增长的负载需求。负载均衡技术应运而生,通过将请求合理分配到多个服务器,有效提高系统的可用性和响应速度。本文将深入探讨负载均衡的基本概念和技术原理,分析其在现代互联网架构中的重要性及应用场景。 ... [详细]
  • 2019年后蚂蚁集团与拼多多面试经验详述与深度剖析
    2019年后蚂蚁集团与拼多多面试经验详述与深度剖析 ... [详细]
  • 利用Redis HyperLogLog高效统计微博日活跃和月活跃用户数
    本文探讨了如何利用Redis的HyperLogLog数据结构高效地统计微博平台的日活跃用户(DAU)和月活跃用户(MAU)数量。通过HyperLogLog的高精度和低内存消耗特性,可以实现对大规模用户数据的实时统计与分析,为平台运营提供有力的数据支持。 ... [详细]
author-avatar
mobiledu2502897297
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有