MySQL优化

1,定位慢查询

增、删、改10%,查询90%

数据库引擎

  • MyISAM:不支持事务,用于只读程序提高性能
  • InnoDB:支持ACID事务、行级锁、并发
  • Berkeley DB:支持事务
//设置命令结束符
DELIMITER $$ //创建表
CREATE TABLE emp
(
empno MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,
ename VARCHAR(20) NOT NULL DEFAULT '',
job VARCHAR(9) NOT NULL DEFAULT '',
mgr MEDIUMINT UNSIGNED NOT NULL DEFAULT 0,
hiredate DATETIME NOT NULL,
sal DECIMAL(7,2) NOT NULL,
comm DECIMAL(7,2) NOT NULL,
deptno MEDIUMINT UNSIGNED NOT NULL DEFAULT 0
)ENGINE=MYISAM DEFAULT CHARSET=utf8; //获取随机字符串的存储函数
CREATE FUNCTION rand_string(len INT)
RETURNS VARCHAR(255)
BEGIN
DECLARE char_str VARCHAR(100);
DECLARE return_str VARCHAR(255);
DECLARE i INT;
SET char_str = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
SET return_str = '';
SET i = 0;
WHILE i &lt len DO
SET return_str = CONCAT(return_str, SUBSTRING(char_str, FLOOR(1+RAND()*62), 1));
SET i = i + 1;
END WHILE;
RETURN return_str;
END //获取随机4位整数的存储函数
CREATE FUNCTION rand_int()
RETURNS INT(4)
BEGIN
DECLARE i INT DEFAULT 0;
SET i = FLOOR(1 + RAND() * 10000);
RETURN i;
END$$ //批量插入数据的存储过程
CREATE PROCEDURE insert_emp(IN _start INT(10), IN _max_num INT(10))
BEGIN
DECLARE i INT DEFAULT 0;
SET i = 0;
SET autocommit=0; //设置事务不自动提交,但如果是MyISAM(不支持事务)数据库则无效。
WHILE i &lt _max_num DO
SET i = i + 1;
INSERT INTO emp VALUES(_start + i, rand_string(6), 'salesman', 0001, CURDATE(), 2000, 400, rand_int());
END WHILE;
COMMIT;
END$$ //调用存储过程插入5000000条数据
call insert_emp(1, 5000000)$$

MySQL命令

SQL命令 含义
show [session global] status like 'com_insert%'
show [session global] status like 'com_select%'
show status like 'uptime' 显示数据库启动多长时间了
show [session global] status like 'slow_queries'
show [session global] variables like 'long_query_time'
SET [session global] long_query_time=0.5;

定位慢查询

开启慢查询日志,一旦开启后,日志文件的位置在my.ini中找datadir,默认情况下是不会记录慢查询的。

1,关闭当前MySQL服务

net stop mysql

2,启动MySQL并开启慢查询[1]

mysqld --defaults-file=my.ini --long_query_time=0.5 --slow-query-log --log-output=FILE

3, 关闭安全模式

mysqladmin -uroot -p** shut down

或者,如果不想重启数据库,可以在MySQL中执行以下命令,但是对旧的session无效,对新的session才有效。

SET GLOBAL long_query_time=0.5;

SET GLOBAL slow_query_log='ON';

SET GLOBAL log_output='FILE';

SET GLOBAL log_slow_admin_statements='ON';

索引

1,创建索引

create index 索引名 on 表名 (字段名);

2,查看索引

show indexes from 表名;

3,全文索引

create table article (

title varchar(200),

body TEXT,

FULLTEXT(title, body)

) engine=MyISAM charset=utf8;

查询全文索引

select * from article where match(title, body) against('keywords');

查看匹配相关度

select match(title, body) against('keywords') from article;

**Note: **

FULLTEXT类型只在MyISAM引擎中有,InnoDB中没有,MySQL默认使用InnoDB

匹配度超过%50(一半的表数据)的关键字,是不会做全文索引的,这个查询关键字keywords叫停止词(这个特点告诉我们,要做全文索引必须是海量数据)

FULLTEXT不支持中文,需要用sphinx技术去处理中文

4,唯一索引

create table stu(

stuid int primary key,

name varchar(10) unique,

email varchar(50));

create unique index 索引名 on 表名 (字段名)

Note:

主键与唯一索引的区别:

主键索引不能重复、不能为空

唯一索引不能重复、可以为空

explain分析SQL语句

explain select * from 表名 where 条件 \G;

创建复合索引(按照字段1查询时索引被使用,按字段2查询时索引不会被使用)

alter table 表名 add index 索引名 (字段1, 字段2)

Note:

如果用主键去查询,自动会使用主键索引

如果创建的是复合索引,只有左边的可以用,右边的不管用。(不要用组合索引)

在模糊查询时,如果like '%keywords'索引不被使用;like 'keywords%'索引被使用

在条件语句中使用or,or两边的字段都必须要有索引,有一个没有,索引就无法使用。

如果字段是字符型的,查询时必须有''引起来,索引才能使用。

选择MySQL存储引擎

MyISAM
不支持事务处理
查询和添加效率高
碎片多
论坛

碎片整理

optimize table 表名

InnoDB
支持事务
保存比较重要的信息
Memory
数据频繁更改,而且不需要在数据库中永久保存
Sesion入库

http://dev.mysql.com/doc/refman/5.6/en/server-options.html

http://dev.mysql.com/doc/refman/5.6/en/log-destinations.html

http://dev.mysql.com/doc/refman/5.6/en/mysqld-option-tables.html


  1. MySQL5.6启动参数 ↩︎

MySQL 慢查询的更多相关文章

  1. Linux下MySQL慢查询分析mysqlsla安装使用

    说明: 操作系统:CentOS 5.X 64位 MySQL版本:mysql-5.5.35 MySQL配置文件:/etc/my.cnf MySQL 数据库存放目录:/data/mysql 实现目的:开启 ...

  2. MySQL的查询计划中ken_len的值计算

    本文首先介绍了MySQL的查询计划中ken_len的含义:然后介绍了key_len的计算方法:最后通过一个伪造的例子,来说明如何通过key_len来查看联合索引有多少列被使用. key_len的含义 ...

  3. mysql的查询、子查询及连接查询

    >>>>>>>>>> 一.mysql查询的五种子句         where(条件查询).having(筛选).group by(分组). ...

  4. MySQL慢查询日志总结

    慢查询日志概念 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志 ...

  5. 【转】Mysql联合查询union和union all的使用介绍

    Mysql的联合查询命令UNION和UNION ALL,总结了使用语法和注意事项,以及学习例子和项目例子,需要的朋友可以参考下 一.UNION和UNION ALL的作用和语法 UNION 用于合... ...

  6. mysql慢查询日志分析工具 mysqlsla(转)

    mysql数据库的慢查询日志是非常重要的一项调优辅助日志,但是mysql默认记录的日志格式阅读时不够友好,这是由mysql日志记录规则所决定的,捕获一条就记录一条,虽说记录的信息足够详尽,但如果将浏览 ...

  7. Mysql慢查询和慢查询日志分析

     Mysql慢查询和慢查询日志分析   众所周知,大访问量的情况下,可添加节点或改变架构可有效的缓解数据库压力,不过一切的原点,都是从单台mysql开始的.下面总结一些使用过或者研究过的经验,从配置以 ...

  8. [django/mysql] 使用distinct在mysql中查询多条不重复记录值的解决办法

    前言:不废话.,直接进入正文 正文: 如何使用distinct在mysql中查询多条不重复记录值? 首先,我们必须知道在django中模型执行查询有两种方法: 第一种,使用django给出的api,例 ...

  9. MySQL 慢查询日志分析及可视化结果

    MySQL 慢查询日志分析及可视化结果 MySQL 慢查询日志分析 pt-query-digest分析慢查询日志 pt-query-digest --report slow.log 报告最近半个小时的 ...

  10. mysql datetime查询异常

    mysql datetime查询异常 异常:Value '0000-00-00 00:00:00' can not be represented as java.sql.Timestamp (2011 ...

随机推荐

  1. HDU 5015 233 Matrix

    题意:给定一个矩阵的第0列的第1到n个数,第一行第1个数开始每个数分别为233, 2333........,求第n行的第m个数. 分析: 其实也没那么难,自己想了半天还没往对的方向想,m最大1e9,应 ...

  2. [jobdu]数组中的逆序对

    http://ac.jobdu.com/problem.php?pid=1348 数组中的逆序对也是个常见的题目,算法导论中也有一些描述,参考:http://www.cnblogs.com/wuyue ...

  3. FireMonkey vs. VCL (FMX的UI更灵活,图形效果更强,硬件加速,内嵌3D,使用浮点数更精确,跨平台,可使用Mida converter转换和TFireMonkeyContainer内嵌)

    Frequently when I am talking about the VCL or FireMonkey I get some of these common questions: Is VC ...

  4. 学习kernel编程的建议

    我把我学习kernel编程的过程介绍给大家,希望大家有个参考. 学习kernel编程需要阅读大量的kernel方面的书籍,在此我列举一下我读过的kernel书籍(按时间先后顺序),并给一些建议. 1. ...

  5. APP-FND-01706: Error Updating TABLE_NAME In FND_DOCUMENT_SEQUENCES (文档 ID 338026.1)

    In this Document Symptoms Cause Solution Applies to: Oracle Order Management - Version 11.5.10.0 and ...

  6. Oracle 常用符号CHR

    select  chr(92)||chr(102) from dual; \f select  chr(92)||chr(110) from dual; \n select  chr(92)||chr ...

  7. 对easyUI中课堂源码编辑改进建议

    在孙宇老师讲得Easyui第10讲完后,基本的增删该查做出来了,但是编辑存在一个问题:行内样式编辑修改,如果当用户没有修改数据,孙宇老师讲得时候直接return,这样做是不合理的:第二次再使用右键编辑 ...

  8. Sharepoint 2010 用VS定制Master,并且每个Web应用同一个Master

    转:http://***/html/blogs/20130407/1381.htm 最近做了一个项目管理系统,要求用Sharepoint,有个特别的功能就是通过创建出来的子站点要求应用同一个Maste ...

  9. 点这里进入ABP系列文章总目录

    基于DDD的现代ASP.NET开发框架--ABP系列之1.ABP总体介绍 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称. ASP.NET Boi ...

  10. 用Eclipse和GDB构建ARM交叉编译和在线调试环境

    我们在 Linux 主机中搭建我们的开发环境,使用 Ubuntu 10.04 LTS 为例. 搭建应用开发环境   安装 JRE Eclipse 依赖于Java 环境,所以必须先安装 JRE 或 JD ...