mysql数据库优化之表的设计和慢查询定位
一、数据库优化包含的方面
数据库优化是一种综合性的技术。并非通过某一种方式让数据库效率提高非常多。而是通过多方面的提高。从而使得数据库性能提高。
主要包含:
1、表的设计合理化(3范式)
2、给表加入合适的索引。怎样使用索引
3、分表技术(水平切割、垂直切割)
4、定时清除数据垃圾,定时碎片整理
5、多用存储过程和触发器
6、对mysql配置进行优化
7、读写分离
8、mysqlserver硬件升级。
二、数据库的设计
步骤:
1、收集信息:与该系统有关人员进行交流。充分了解数据库须要完毕的任务
2、标识实体:详细存在的对象,名词。
比方:用户、帖子、回帖、板块
3、标识属性
4、标识关系:
1)一对一:两个表的主键是公共字段
2)一对多:主键和非主键建关系
3)多对一:非主键和主键建关系
4)多对多:非主键和非主键建关系
5、将E-R图转成表
1)将实体转成表,将属性转成字段
2)假设找不到一个合适的字段做主键,我们加入一个自己主动增长列做主键。
3)建立正确的关系
三、数据规范化
表设计出来以后,并非最合理的结构。我们须要对表进行规范化(我们通过3范式来对表进行规范化)
先满足第一范式--再满足第二范式--再满足第三范式
1NF: 确保每列的原子性
第一范式用来规范化全部的字段,全部的字段都不可再分
注意:比方地址这个字段。假设不分类汇总、不排序。只起一个字符串的作用。这时我们不拆(反3范式)
2NF: 非键字段必须依赖于主键字段
假设一个关系满足1NF,而且除了主键以外其它列都依赖于该主键,则满足第二范式(2NF)
3NF: 消除传递依赖
在非主键字段中。假设一个字段能够推导还有一个字段,这就叫传递依赖。
四、规范化和性能的关系
1、为了满足某种商业目标。数据库性能比规范化数据库更重要
通过对给定的表中加入额外的字段,以大量降低须要从中搜索信息所须要的时间。
通过在给定的表中插入计算列(比方成绩总分),以方便查询
2、进行规范化的同一时候须要考虑数据库的性能
五、定位慢查询
找出查询速度较慢的SQL语句。
增、删、改、查
当中查询占90%,增删改共占10%
Mysql数据库一些关于状态的查询
用"show status"
指令 说明
show status 查询mysql数据库的一些执行状态
show status like 'com_insert'; 显示运行了多少次插入操作
show status like 'com_update'; 显示运行了多少次更新操作
show status like 'com_delete'; 显示运行了多少次删除操作
show status like 'com_select'; 显示运行了多少次查询操作
show status like 'uptime'; 显示mysql启动了多长时间,假设时间非常长了,数据库表的存储引擎有的是myisam,这时候注意要碎片整理。
show [session | global ] status like...,假设不写,默认是会话级(session),想要查询从mysql启动一直到如今,用global。
显示慢查询
show variables like 'long_query_time' 显示慢查询的时间,默认是10秒
set long_query_time=0.5 把慢查询的时间设置为0.5秒,以便于測试
show status like 'slow_queries' 显示慢查询的时间,默认是10秒
定位慢查询(开启慢查询日志)
一旦开启慢查询日志以后。日志文件的位置在my.ini文件里去查找,默认情况下mysql不会记录慢查询
怎样开启慢查询:
1、关闭当前mysql服务:net stop mysql
2、通过安全模式启动就会写日志。
3、关闭安全模式启动的mysql
4、把慢查询的时间设置为0.5秒,set long_query_time=0.5
5、select * from table where xx='00' ;
6、到慢查询日志中去找相应的SQL语句。
反三范式:
范式越高。数据冗余就越少,可是有时就效率就越低下,为了提高执行效率,能够适当的让数据冗余。
mysql数据库优化之表的设计和慢查询定位的更多相关文章
- MYSQL 数据库名、表名、字段名查询
//查询所有表的所有字段: select * from information_schema.columns where table_name='sys_users' 效果: //查询指定表的所有字段 ...
- mysql数据库优化课程---11、mysql普通多表查询
mysql数据库优化课程---11.mysql普通多表查询 一.总结 一句话总结:select user.username,user.age,class.name,class.ctime from u ...
- MySQL数据库优化、设计与高级应用
MySQL数据库优化主要涉及两个方面,一方面是对SQL语句优化,另一方面是对数据库服务器和数据库配置的优化. 数据库优化 SQL语句优化 为了更好的看到SQL语句执行效率的差异,建议创建几个结构复杂的 ...
- mysql数据库优化课程---16、mysql慢查询和优化表空间
mysql数据库优化课程---16.mysql慢查询和优化表空间 一.总结 一句话总结: a.慢查询的话找到存储慢查询的那个日志文件 b.优化表空间的话可以用optimize table sales; ...
- mysql数据库优化课程---3、数据库设计是什么
mysql数据库优化课程---3.数据库设计是什么 一.总结 一句话总结: 就是设计各个字段及各个字段类型 1.char,varchar,text同存'ABC'的存储空间为多少? char(255): ...
- 30多条mysql数据库优化方法,千万级数据库记录查询轻松解决(转载)
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
- 50多条mysql数据库优化建议
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 缺省情况下建立的索引是非群集索引,但有时它并不是最佳的.在非群集索引下,数据在物理上随机存 ...
- 解开发者之痛:中国移动MySQL数据库优化最佳实践(转)
开源数据库MySQL比较容易碰到性能瓶颈,为此经常需要对MySQL数据库进行优化,而MySQL数据库优化需要运维DBA与相关开发共同参与,其中MySQL参数及服务器配置优化主要由运维DBA完成,开发则 ...
- 30多条mysql数据库优化方法【转】
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
随机推荐
- gcc编译问题
gcc avl.o hash.o list.o rb.o example.o -o 123.exe 多个.o输出 exe -c和-o都是gcc编译器的可选参数.-c表示只编译(compile)源文件但 ...
- 单片微机原理P1:80C51指令系统和编程方法
0. 寻址方式 寻址方式在汇编中是很重要的,汇编所有的操作都是和和内存或者寄存器打交道的,在80C51里面一共7种寻址方式. 1. 立即寻址: 这个没什么好说的,就是往寄存器或者内存里面写立即数, ...
- 用户管理命令--useradd
用户管理命令--useradd 作用:用于添加一个新的用户 格式:useradd [ 选项 ] 用户名 选项的常用介绍 -u: UID指定用户id,必须是唯一的,并且大于499 -c: 添加注释,可以 ...
- Navicat Premium 12破解(转载)
一.Navicat Premium 12下载 Navicat Premium 12是一套数据库开发管理工具,支持连接 MySQL.Oracle等多种数据库,可以快速轻松地创建.管理和维护数据库. Na ...
- Django框架基础知识14-类视图
MTV view视图 wsgi函数 def index(request): .... return HttpResponse() 特定的HTTP方法.get,post可以定义单独的方法 继承,多继承, ...
- 前端基础之CSS_2
摘要 盒子模型 浮动 清除 溢出 定位 模态框 rgba 与 opacity透明区别 一.CCS盒子模型 margin:标签与标签之间的距离,主要用于控制标签周围间的间隔,从视觉上达到相互分开的目的 ...
- 关于一个多个.cpp文件的项目中,函数出现未定义引用错误
编译的话,必须把全部的c文件都要编译的啊,只编译一个c算怎么个逻辑呢?编译实际上是2个过程,编译和链接.编译过程只检查所有的符号(变量,函数)有没有声明,即只需要h文件生命就够了.但是链接时候,需要找 ...
- There is no getter for property named 'id' in class 'java.lang.String'
https://blog.csdn.net/u011897392/article/details/46738747 使用mybatis传入参数,如果在mappin.xml中使用<if>标签 ...
- Leetcode 230.二叉搜索树第k小的数
二叉搜索树第k小的数 给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 个最小的元素. 说明:你可以假设 k 总是有效的,1 ≤ k ≤ 二叉搜索树元素个数. 示例 1: 输 ...
- 如何解决安装istio后istioctl命令每次使用都需要重新配置路径
Kubernetes在安装istio后初次使用istioctl命令时会提示istioctl command not found 这时候如果在istio文件夹的根目录下配置 export PATH=$P ...