MySql 学习笔记一:SQL语句优化

时间:2022-09-21 23:39:56

一、数据库三范式

第一范式:1NF是对属性的原子性约束,要求属性(列)具有原子性,不可再分解;(只要是关系型数据库都满足1NF)
第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;
第三范式:3NF是对字段冗余性的约束,它要求字段没有冗余。 没有冗余的数据库设计可以做到。
但是,没有冗余的数据库未必是最好的数据库,有时为了提高运行效率,就必须降低范式标准,适当保留冗余数据。具体做法是: 在概念数据模型设计时遵守第三范式,降低范式标准的工作放到物理数据模型设计时考虑。降低范式就是增加字段,允许冗余。

二、SQL语句优化

1、SQL优化的一般步骤

  1. 通过show status命令了解各种SQL的执行频率。
  2. 定位执行效率较低的SQL语句-(重点select)
  3. 通过explain分析低效率的SQL语句的执行情况
  4. 确定问题并采取相应的优化措施

2、SQL语句优化-show参数

MySQL客户端连接成功后,通过使用show [session|global] status 命令可以提供服务器状态信息。其中的session来表示当前的连接的统计结果,global来表示自数据库上次启动至今的统计结果。默认是session级别的。下面的例子:

show status like 'Com_%';

其中Com_XXX表示XXX语句所执行的次数。
重点注意:Com_select,Com_insert,Com_update,Com_delete通过这几个参数,可以容易地了解到当前数据库的应用是以插入更新为主还是以查询操作为主,以及各类的SQL大致的执行比例是多少。
比如:

SHOW status LIKE 'Com_select';

MySql 学习笔记一:SQL语句优化

还有几个常用的参数便于用户了解数据库的基本情况。
Connections:试图连接MySQL服务器的次数
Uptime:服务器工作的时间(单位秒)
Slow_queries:慢查询的次数 (默认是慢查询时间10s)

show status like 'connections'; 
-- 显示慢查询次数
show status like 'slow_queries';
-- 修改慢查询界定时间为2秒
set long_query_time=2;

3、SQL语句优化-定位慢查询

(未测试)

在默认情况下mysql不记录慢查询日志,需要在启动的时候指定:

bin\mysqld.exe - -safe-mode  - -slow-query-log [mysql5.5 可以在my.ini指定]
bin\mysqld.exe –log-slow-queries=d:/abc.log [低版本mysql5.0可以在my.ini指定]

先关闭mysql,再启动, 如果启用了慢查询日志,默认把这个文件放在
my.ini 文件中记录的位置
Path to the database root
datadir=”C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.5/Data/”
先定位到mysql安装目录中bin文件夹所在的目录(未尽到bin文件夹内部)
再执行命令
MySql 学习笔记一:SQL语句优化
通过慢查询日志定位执行效率较低的SQL语句。慢查询日志记录了所有执行时间超过long_query_time所设置的SQL语句。

本文部分内容整理自itcast讲义,在此表示感谢。
作者:jiankunking 出处:http://blog.csdn.net/jiankunking