MYSQL慢速(SLOW LOG)脚本分析

mysql有一个功能就是可以log下来运行的比较慢的sql语句,默认是没有这个log的,为了开启这个功能,
要修改my.cnf或者在mysql启动的时候加入一些参数。如果在my.cnf(Windows为my.ini文件)里面修改,需增加如下几行

long_query_time = 1
log-slow-queries = /var/youpath/slow.log
log-queries-not-using-indexes

long_query_time 是指执行超过多久的sql会被log下来,这里是1秒。
log-slow-queries 设置把日志写在那里,可以为空,系统会给一个缺省的文件host_name-slow.log,
log-queries-not-using-indexes 就是字面意思,log下来没有使用索引的query。

mysql有以下几种日志:
错误日志:   -log-err
查询日志:   -log
慢查询日志:     -log-slow-queries
更新日志:     -log-update
二进制日志:   -log-bin

把上述参数打开,运行一段时间,就可以关掉了,详细请见http://blog.haohtml.com/index.php/archives/2772

接下来就是分析了,这里的文件名字叫host-slow.log。
先mysqldumpslow –help以下,e它主要用的是
-s ORDER what to sort by (t, at, l, al, r, ar etc), ‘at’ is default
-t NUM just show the top n queries
-g PATTERN grep: only consider stmts that include this string

-s,是order的顺序,说明写的不够详细,主要有
c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒叙
-t,是top n的意思,即为返回前面多少条的数据
-g,后边可以写一个正则匹配模式,大小写不敏感的

mysqldumpslow -s c -t 20 host-slow.log
mysqldumpslow -s r -t 20 host-slow.log

上述命令可以看出访问次数最多的20个sql语句和返回记录集最多的20个sql。
mysqldumpslow -t 10 -s t -g “left join” host-slow.log
这个是按照时间返回前10条里面含有左连接的sql语句。

用了这个工具就可以查询出来那些sql语句是性能的瓶颈,进行优化,比如加索引,该应用的实现方式等。

mysqldumpslow -s c -t 10 /tmp/slow_query.log


mysql中自动修改数据表的设计(默许的数据列修改)

9.9.6 自动修改数据表的设计(默许的数据列修改)

在创建(create table)或修改(alter table)一个数据表的时候,MYSQL会在特定条件下对这个数据表的设计方案自动做出一些修改,其理由或者是那么做可以让数据表的效率更高,或者是设计思路MYSQL无法实现.
这里要特别提醒那些从期货数据库系统迁移过来的读者注意:MYSQL在对数据表设计方案自动做出勤率修改时不会给出任何提示,所以一事实上要用SHOW CREATE TABLE命令去检查一下最终的数据表设计方案是不是所想像的样子。在下面的例子里。MYSQL自做主张地把一个CHAR(2)数据列改成了一个VARCHAR(20)数据列,还给那两个数据列加上了defautl null属性.
CREATE TABLE test1(col1 VARCHAR(20), col2 CHAR(20))
show create table test1
create table test1(
col1 varchar(20) default null,
col2 varchar(20) default null
)engine=MYISAM default charset=latin1

以下是mysql会对数据表设计方案自动做出的几项重大修改:
1.如果n<4,VARCHAR(n)数据列将被修改为CHAR(n)数据列.
2.如果n>3,并且在同一个数据表里还有其他的VARCHAR,TEXT,或BLOG数据列的话,CHAR(n)将被系统自动修改为CARCHAR(n).如果数据表里只有固定长度的数据列,但CHAR(n)将不发生变化.
3.即使没有设定,MYSQL也会自动给primary key数据列自动加上NOT NULL属性.
mysql文档把这种自动方式的修改称为默许的数据列修改(client column changes),这方面的详细信息可以在HTTP://dev.mysql.com/doc/mysql/en/silent-column-changes.html网址处的文章里找到。
总之在数据库的设计和创建工作这后,一定要仔细检查数据库,数据库里的数据表,数据表里的数据列,数据列的各有关属性是不是都如所想.

以上摘自<<Mysql 5 权威指南>>第3版 第195页