• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 深入理解MySQL进阶漂流记(六)

深入理解MySQL进阶漂流记(六)

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL,进阶,漂流记等相关知识,希望本文的分享对您有所帮助

性能优化

索引

索引指向数据库中具体数据所在的一个位置,同事在列上创建一个索引可以排列该列上的信息。当服务器需要访问该信息进行 查询时,就会知晓在什么地方进行查询,因为索引指向有关位置。

如果一个列涉及查询,分组,排序,索引将可以达到提高性能的效果。
带很多重复值的索引不会产生很好的结果。
可以使用表来联合多个非唯一的索引,以便改善性能。
索引越多,性能不一定越好。添加一个索引,并不一定能改善性能。

查询高速缓存

在运行select查询时,MySQL4.x会记录下查询和返回结果。这是通过select每次进行查询时,在一个特殊的高速缓存中保存 结果集实现的。然后,当再次请求服务器做相同的查询时,MySQL将会从高速缓存中检索结果,而不是再次运行该查询。 默认情况下是启动这个性能。

注意,一旦表有变化,使用这个表的高速缓存查询就变成无效,并且将从高速缓存中删除。这样防止查询从旧表上返回 不准确的数据。经常有变化的表,将不会从高速缓存中得到利益。这种情况,可以考虑不使用高速缓存, 可以添加一个选项sql_no_cache来实现。

查询分析

在select查询开始处加上一个explain关键字,将告诉MySQL返回一个图表,说明这个查询如果进行处理, 在这个图表里涉及了查询将访问哪个表的信息以及查询希望返回的行数的信息。这个信息可以用来查看哪些表可以添加索引, 以便加快执行速度,分析瓶颈的位置。

通过查询的显示结果,可以知道什么位置可以添加索引,进行迅速的改正。

优化多表查询

子查询是一个嵌套在另一个select语句中的select语句。子查询经常用来把一个复杂的查询拆分为一些列的逻辑步骤, 或者使用其他查询结果回答一个查询。其结果是不需要执行两个或者更多的单独查询,就可以执行一项包含一项或者多项子查询 的简单查询。

MySQL可以比子查询更好的优化连接,所以如果发现在自己的MySQL服务器上的负载平均值达到了无法接受的高水平,就应该 检验应用程序代码,并试着重写作为连接和连接序列的子查询。

可以通过有效的使用MySQL的集合性能和修改程序来把低效的子查询转变为更为有效的连接。
如果希望避免中间使用嵌套查询,还可以使用基于会话的服务器变量。

使用临时表

MySQL还允许使用create temporary table命令创建临时表。这种表之所以这么称呼,是因为它只针对单一的MySQL会话 过程而存在的,当使用这些表的客户机关闭了与MySQL服务器的连接时,它将自动删除。

因为临时表保存在内存中,所以要比基于磁盘的表明显的快。结果可以有效的作为中间存储区域,以便提高查询实施的速度, 帮助把复杂的的拆分为更简单的部件,或者作为子查询和连接支持的代替。

优化表设计

为了使查询能够更加精炼,需要考虑表设计方面的一些因素。首先,如果经常查询的表会发生很多变化,改进性能的方式就是使用 定长字段,不适用变长字段。虽然使用定长字段将浪费更多的磁盘空间,但是从查询角度看,MySQL处理定长字段比变长字段更快。

改善性能的另一项技术是使用optimize table命令处理经常需要修改的表。经常修改表会导致磁盘碎片,以致花费额外的时间 去读取没有用的空间块,以便得到希望的数据。

在考虑改善性能时,还要检查是否需要针对已经建立的所有表。额外的表意味着性能降低。没有必要合并的表,则应试着匹配连接的 列。

调整服务器设置

如果希望服务器更加有效的运行,最佳解决方案是加大内存空间和使用更大更快的磁盘。但是更多时候,条件是不允许是的。 此时,我们需要一些改进服务器的常规技术。

调整服务器变量,key_buffer_size变量控制MySQL索引缓冲可以使用内存的数量。值越高,索引可以使用的内存越多,性能越好。 一般情况,这个值保持在可使用内存总量的25%到30%。table_cache变量控制表高速缓存可以使用内存的数量,以及在同一时间 内MySQL可以处理表的打开总量。对于有很多数据库和表的非常忙的服务器来说,应该增加这个值,使用set修改。

一旦修改了一个全局服务器变量,关闭服务器之前,这些变量一直存在,但是重启服务器之后,变量恢复默认状态。 所以最好是进行永久性修改。


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05SQL Server 7.0 入门(六)
  • 2018-12-05MYSQL解锁和锁表的实例详解
  • 2018-12-05MySQL 清除表空间碎片的实例详解
  • 2017-05-11Mysql LONGBLOB 类型存储二进制数据 (修改+调试+整理)
  • 2018-12-05怎样将MySQL中两千万数据进行优化与迁移
  • 2018-12-05MySQL如何修改开启允许远程连接的实例详解
  • 2018-12-05DDL语句的实例详解
  • 2018-12-05linux下mysql自动备份数据库与自动删除临时文件
  • 2018-12-05.net2.0连接Mysql5数据库配置
  • 2018-12-05MSSQL中递归SQL查询语句实例说明-

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL 5.7新特性| Json Column和Generated Column(上)
    • 使用innodb_force_recovery解决MySQL崩溃无法重启问题
    • Mongodb之(小试牛刀)
    • 深入MYSQL字符数字转换的详解
    • MySQL 存储过程的基本用法介绍
    • 关于SQL Server的最新更新
    • show engine innodb status显示信息不全如何解决
    • SQLServer XML数据的五种基本操作
    • 如何在一台windows主机上实现MySQL的主从复制?
    • 一条SQL语句变得巨慢的原因及其解决方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有