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

MySQL性能优化的17个要点

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

匿名通过本文主要向大家介绍了MySQL,改善性能等相关知识,希望本文的分享对您有所帮助
数据库管理员把他们生命中的相当一部份时间花在了调整、试验以改善DBMS性能之上。在诊断应用的滞缓现象和性能问题时,性能不良的数据库(以及数据库查询)通常是最常见的祸因。

可以看出,下面的内容并不能完全决定MySQL的性能。我们只是想回顾一下前面各章的重点,提供进行性能优化探讨和分析的一个出发点。

以下是具体的MySQL性能优化的17个要点:

1.首先,MySQL(与所有DBMS一样)具有特定的硬件建议。在学习和研究MySQL时,使用任何旧的计算机作为服务器都可以。但对用于生产的服务器来说,应该坚持遵循这些硬件建议。

2.一般来说,关键的生产DBMS应该运行在自己的专用服务器上。

3.MySQL是用一系列的默认设置预先配置的,从这些设置开始通常是很好的。但过一段时间后你可能需要调整内存分配、缓冲区大小等。(为查看当前设置,可使用 SHOW VARIABLES; 和 SHOW STATUS; 。)

4.MySQL一个多用户多线程的DBMS,换言之,它经常同时执行多个任务。如果这些任务中的某一个执行缓慢,则所有请求都会执行缓慢。如果你遇到显著的性能不良,可使用 SHOW PROCESSLIST显示所有活动进程(以及它们的线程ID和执行时间)。你还可以用KILL 命令终结某个特定的进程(使用这个命令需要作为管理员登录)。

5.总是有不止一种方法编写同一条 SELECT 语句。应该试验联结、并、子查询等,找出最佳的方法。

6.使用 EXPLAIN 语句让MySQL解释它将如何执行一条 SELECT 语句。

7.一般来说,存储过程执行得比一条一条地执行其中的各条MySQL语句快。

8.应该总是使用正确的数据类型。

9.决不要检索比需求还要多的数据。换言之,不要用 SELECT * (除非你真正需要每个列)。

10.有的操作(包括 INSERT )支持一个可选的 DELAYED 关键字,如果使用它,将把控制立即返回给调用程序,并且一旦有可能就实际执行该操作。

11.在导入数据时,应该关闭自动提交。你可能还想删除索引(包括FULLTEXT 索引),然后在导入完成后再重建它们。

12.必须索引数据库表以改善数据检索的性能。确定索引什么不是一件微不足道的任务,需要分析使用的 SELECT 语句以找出重复的WHERE 和 ORDER BY 子句。如果一个简单的 WHERE 子句返回结果所花的时间太长,则可以断定其中使用的列(或几个列)就是需要索引的对象。

13.你的 SELECT 语句中有一系列复杂的 OR 条件吗?通过使用多条SELECT 语句和连接它们的 UNION 语句,你能看到极大的性能改进。

14.索引改善数据检索的性能,但损害数据插入、删除和更新的性能。如果你有一些表,它们收集数据且不经常被搜索,则在有必要之前不要索引它们。(索引可根据需要添加和删除。)

15.LIKE 很慢。一般来说,最好是使用 FULLTEXT 而不是 LIKE 。

16.数据库是不断变化的实体。一组优化良好的表一会儿后可能就面目全非了。由于表的使用和内容的更改,理想的优化和配置也会改变。

17.最重要的规则就是,每条规则在某些条件下都会被打破。

【相关推荐】

1. Mysql免费视频教程

2. mysql诊断启动问题、查看日志文件详解

3. MySQL数据库的备份与维护详解

4. MySQL设置访问权限实例详解

5. MySQL创建用户账号和删除用户账号

以上就是MySQL性能优化的17个要点的详细内容,更多请关注微课江湖其它相关文章!

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

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

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

相关文章

  • 2018-12-05理解redo(9)10g R2后oracle对redo写的增强
  • 2018-12-05分享SQL Server删除重复行的6个方法
  • 2018-12-05mysql中视图如何使用?mysql中视图用法实例汇总
  • 2018-12-05mysql教程:mysql索引的类型
  • 2018-12-05mysql记录根据日期字段倒序输出_MySQL
  • 2017-05-11MySQL ALTER语法的运用方法
  • 2018-12-05mysql数据类型详细介绍
  • 2018-12-05mysql索引的设计和使用
  • 2018-12-05两种不停止 MySQL 服务增加从库的方式
  • 2017-05-11FROM_UNIXTIME 格式化MYSQL时间戳函数

文章分类

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

最近更新的内容

    • mysql错误代码查询
    • Linux利用mysqld_multi单机启动多个MySQL实例
    • mysqlhotcopy 正则使用小技巧
    • Oracle 自增(auto increment) 或 标识字段的建立方法_Oracle应用
    • 详细介绍最新Linux系统下安装MySql5.7.17全过程和注意事项
    • Access使用查询
    • MYSQL导入导出命令详解
    • SQL2005日志收缩方法
    • 删除MySQL重复数据的方法
    • 关于mysql5.7.18的安装并修改初始密码的图文教程

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

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