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

12个优化MySQL的技巧小整理

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql使用技巧,mysql查询技巧,mysql技巧,mysql数据库的优化,mysql的sql优化等相关知识,希望本文的分享对您有所帮助

 避免编辑转储文件

Mysqldump创建的转储文件原本是无害的,但它很容易被尝试去编辑。然而,人们应该知道在任何情况下的试图修改这些文件被证明是有危险的。直观地看对这些文件的改动会导致数据库损坏,从而导致系统的退化。为了让你的系统免受任何麻烦,你必须避免编辑MySQL转储文件。

MyISAM 块大小

大多数开发者忘记了这一事实,文件系统往往需要一个大的MyISAM块以保证高效运行。许多开发者不知道块大小的设置。.MYI文件存储在myisam_block_size的设置里,这个设置项可用来修改大的块尺寸。MyISAM块大小的默认值是1K,这不是当前大多数系统的恰当设置。因此,开发者应该考虑指定一个与之相适应的值。

打开 Delay_Key_Write

为避免系统崩溃时数据库损坏delay_key_write默认是关闭的。有人可能会问,如果是这样的话,为什么要把它放在首位打开呢?从防止数据库每次写MyISAM key文件时刷该文件方面看这是必要的。通过把它打开,开发者可以节省很多时间。参考MySQL官方手册了解你的版本如何把它打开。

Joins(表连接)

创建索引和使用相同的列类型:join(表连接)操作可以在Mysql中被优化。若应用中有许多join操作,可以通过创建相同的列类型上join来优化。创建索引是加速应用的另一种方法。查询修改有助于你找回期望的查询结果。

优化WHERE从句

即使你只搜索一行MySQL也会查询整个表,因此,建议你当只需要一条结果时将limit设置为1。通过这样做,可以避免系统贯穿搜索整个表,从而可以尽可能快找到与你需求相匹配的记录。

在Select查询上使用Explain关键字

你肯定希望得到与任何特定查询相关的一些帮助。Explain关键词在这方面是非常有帮助的。它在你寻求查询到底做了什么时提供了具体细节。例如,在复杂join查询前键入Explain关键词你会得到很多有用的资料。

使用查询缓存优化查询

MySQL的查询缓存是默认启用的。这主要是因为缓存有助于查询的快速执行,缓存可以在相同的查询多次运行使用。你在关键字前加入当前日期、CURRDATE等PHP代码使查询缓存它从而启用此功能。

使用堆栈跟踪隔离Bug

各种Bug可以使用stack_trace隔离出来。一个空指针足以毁掉一段特定的代码,任何开发人员都知道它有这样的能力。了解使用堆栈跟踪的细节,从而在你的代码里避免bug。

设置SQL_MODE

枚举类型总是让人感到非常的疑惑。由于字段可能拥有多个可能的值,这些可能的值包括你指定的和null,在编码时将会出现很多问题,你将永远都会得到一个警告说代码不正确。一个简单的解决办法就是设置SQL_MODE。

        $–sql-mode=”modes”
    //or
    $sql-mode=”modes” (my.ini – Windows / my.cnf – Unix)
    //Change at runtime, separate multiple modes with a comma
    $set [GLOBAL|SESSION] sql_mode='modes'
    //TRADITIONAL is equivalent to the following modes:
    STRICT_TRANS_TABLES, STRICT_ALL_TABLES, NO_ZERO_IN_DATE, ERROR_FOR_DIVISION_BY_ZERO, and NO_AUTO_CREATE_USER</div>

修改Root密码

修改root密码对于某些特定设置是必不可少的,修改命令如下:

        $mysqladmin -u root password [Type in selected password]
    //Changing users ROOT password
    $mysqladmin -u root -p [type old password] newpass [hit enter and type new password. Press enter]
    //Use mysql sql command
    $mysql -u root -p
    //prompt “mysql>” pops up. Enter:
    $use mysql;
    //Enter user name you want to change password for
    $update user set password=PASSWORD (Type new Password Here) where User = ‘username';
    //Don't forget the previous semicolon, now reload the settings for the users privileges
    $flush privileges;
    $quit</div>

用MySQL Dump 命令备份数据库

开发者都知道数据库备份的重要性,当系统出现重大故障时能够起到救命的作用。

最简单的备份数据库的方法
 
//你也可以用简写"-u","-p"来分别代替"user"和"password"
//将多个数据库导入到一个文件只要在后面添加需要导出数据库的名称:
 
[first database name] [second database name] > [dump file] </div>
//许多数据库都提供了顺序备份的功能,要备份所有数据库只需要添加--all-databases参数。如果你不喜欢命令行,从Sourceforge上下载automysqlbackup吧。

调整CONFIG的配置

PERL脚本MySQL Tuner是另一个强大的优化数据库性能的工具,它能够帮助你对MySQL配置来进行多处调整和修改。你可以访问该项目的官网来进一步了解它。

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

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

  • 有关mysql的一些小技巧
  • mysql 服务完全卸载技巧
  • 12个优化MySQL的技巧小整理
  • mysql技巧:提高插入数据(添加记录)的速度
  • 101个MySQL优化技巧和提示
  • 总结MySQL建表、查询优化的一些实用小技巧

相关文章

  • 2017-05-11MySQL创建用户与授权方法
  • 2017-05-11浅谈开启magic_quote_gpc后的sql注入攻击与防范
  • 2018-12-05MySQL索引原理和慢查询优化
  • 2018-12-05Mysql-主多从和读写分离配置的代码示例简介
  • 2018-12-05mysql数据库操作性能优化方式汇总
  • 2018-12-05详细介绍关于MYSQL和ORACLE的区别
  • 2018-12-05MS SQL Server和MySQL区别
  • 2018-12-05Oracle In和exists not in和not exists的比较分析
  • 2018-12-05MySQL高级十七——MySQL账号权限赋予
  • 2018-12-05SqlServer 序号列的实现方法

文章分类

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

最近更新的内容

    • 在Windows主机上定时备份远程VPS(CentOS)数据的批处理
    • MySql数据引擎简介与选择方法
    • MySQL5.7.19在Linux下安装出现的问题解决图文详解
    • 使用FriendFeed来提升MySQL性能的方法
    • 关于奇偶数的详细介绍
    • 如何写一个属于自己的数据库封装(5)
    • MySQL事务autocommit自动提交
    • union这个连接是有什么用的和INNER JOIN有什么区别
    • MySQL误操作后快速恢复数据的方法
    • mysql:Can't start server: can't create PID file: No space left on device

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

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