mysql数据库的优化技术
- 表的设计合理化(遵从3NF)<3范式>
- 1NF:表的列具有原子性,不可再分解(列的信息不能分解,只要是关系型的数据库就自动满足1NF)
- 2NF:表中的记录是唯一的,就满足2NF(通常我们设计一个主键来实现)
- 3NF:表中不要有冗余数据(表中的信息能被推倒出来,就不应该单独成列)
在一对多的情况,为了提高效率,可能会在1中设计字段提高效率(违反3NF)
2. 添加适当的索引(index)[四种:主键,唯一,普通,全文]
(1)主键索引的添加:当一张表,把某个列设为主键时,则该列就是主键索引
create table aaa
( id int unsigned primary key auto_increment,
name varchar(32) not null default ' ');
这时id列就是主键索引。
如果你在创建表时没有指定主键索引,也可以在创建后添加,指令:
alter table 表名 add primary key (列名);
举例:
create table (id int unsigned,name varchar(32) not null default '' );
alter table bbb add pirmary key (id);
(2)唯一索引的添加:
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
UNIQUE (Id_P)
) CREATE TABLE Persons
(
Id_P int NOT NULL UNIQUE,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
)
(3)普通索引的创建:普通索引的创建,是先创建表,然后再创建普通索引。
比如:create table ccc(id int unsigned,name varchar(32));
create index 索引名 on 表(列)
(4)全文索引的创建:主要针对文件,文本的检查,比如文章,全文索引针对MyISAM引擎有用。
CREATE TABLE articles
(
Id_P int NOT NULL UNIQUE,
title varchar(200),
body text,
fulltext(title,body)
)egin=myisam charset utf8;
如何使用全文索引?
错误用法:select *from articles where body like '%mysql%';[这样不会使用到全文索引]
正确用法:select *from articles where match(title,body) against ('database');
说明:
<1>在mysql中fulltext索引只针对myisam生效。
<2>针对英文生效---->sphinx技术处理中文(coreseek)
<3>使用方法 match(字段名) aginst('关键字')
<4>全文索引有一个停止词,因为在一个文本中,创建索引是一个无穷大的数,因此,对一些常用词和字符,就不会创建,这些词称为停止词。
小结:查询索引命令
desc 表表名;
show index(es) from 表名;
show keys from 表名;
3.分表技术[水平分割,垂直分割]
(1)水平分割:
举例:如QQ登录表(假设用户有5亿)
id name pw
1 aa aa
2 bb bb
如果验证5个亿的数据验证,这样的效率过低。假设把数据分成3个表储存,由id%3来决定放入和取出的表。三个表的结构和大表相同。
(2)垂直分割:
某些表的某些字段,在查询的时候,并不关心,但是数据量很大,我们建议把这些大字段单独放到另一张表里,从而提高效率,
但是必须与原表保持关联。
4.读写(写操作包括update、delete、add)分离
5.存储过程(模块化编程,可以提高速度)
6.对mysql配置优化[配置最大并发数,调整缓存大小--->my.ini]
7.mysql服务器硬件升级
8.定时清除不需要的数据,定时进行碎片整理。
mysql数据库的优化技术的更多相关文章
- Mysql数据库性能优化(一)
参考 http://www.jb51.net/article/82254.htm 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要 ...
- mysql数据库性能优化(包括SQL,表结构,索引,缓存)
优化目标减少 IO 次数IO永远是数据库最容易瓶颈的地方,这是由数据库的职责所决定的,大部分数据库操作中超过90%的时间都是 IO 操作所占用的,减少 IO 次数是 SQL 优化中需要第一优先考虑,当 ...
- MySQL 数据库性能优化之缓存参数优化
在平时被问及最多的问题就是关于 MySQL 数据库性能优化方面的问题,所以最近打算写一个MySQL数据库性能优化方面的系列文章,希望对初中级 MySQL DBA 以及其他对 MySQL 性能优化感兴趣 ...
- MYSQL数据库的优化
我们究竟应该如何对MySQL数据库进行优化?下面我就从MySQL对硬件的选择.MySQL的安装.my.cnf的优化.MySQL如何进行架构设计及数据切分等方面来说明这个问题. 服务器物理硬件的优化 在 ...
- MySQL数据库的优化(下)MySQL数据库的高可用架构方案
MySQL数据库的优化(下)MySQL数据库的高可用架构方案 2011-03-09 08:53 抚琴煮酒 51CTO 字号:T | T 在上一篇MySQL数据库的优化中,我们跟随笔者学习了单机MySQ ...
- MySQL数据库的优化(上)单机MySQL数据库的优化
MySQL数据库的优化(上)单机MySQL数据库的优化 2011-03-08 08:49 抚琴煮酒 51CTO 字号:T | T 公司网站访问量越来越大,导致MySQL的压力越来越大,让我们自然想到的 ...
- [转]MySQL数据库的优化-运维架构师必会高薪技能,笔者近六年来一线城市工作实战经验
本文转自:http://liangweilinux.blog.51cto.com/8340258/1728131 年,嘿,废话不多说,下面开启MySQL优化之旅! 我们究竟应该如何对MySQL数据库进 ...
- MySQL 数据库性能优化之索引优化
接着上一篇 MySQL 数据库性能优化之表结构,这是 MySQL数据库性能优化专题 系列的第三篇文章:MySQL 数据库性能优化之索引优化 大家都知道索引对于数据访问的性能有非常关键的作用,都知道索引 ...
- MySQL数据库的优化-运维架构师必会高薪技能,笔者近六年来一线城市工作实战经验
原文地址:http://liangweilinux.blog.51cto.com/8340258/1728131 首先在此感谢下我的老师年一线实战经验,我当然不能和我的老师平起平坐,得到老师三分之一的 ...
随机推荐
- swift3 循环滚动视图 自适应横竖屏 reload数据源
一句话创建banner图,可时时刷新 用到了 SnapKit.SDWebImage两个第三方库 实现步骤------------------------------------------------ ...
- Struts2的通配符配置方式
Struts2的Action类很有意思,你可以使用3种方式来实现具体的Action类: 让你的Action类继承自ActionSupport类(项目中最常用这种方式,因为ActionSupport类中 ...
- 关于ajax跨域问题
什么是跨域 1.document.domain+iframe的设置 2.动态创建script 3.利用iframe和location.hash 4.window.name实现的跨域数据传输 5.使用H ...
- ES CPU和磁盘IO升高
问题 ES监控出现偶尔的波动,CPU和磁盘IO升高 有时候在凌晨,业务请求比较低,也没有慢查询,GC也比较正常,没有出现Full GC ES内部的merge segment会占用CPU和磁盘资源,怀疑 ...
- jQuery的animate在火狐浏览器上不支持backgroundPositionX的解决方法
在网上找的ffSupp.js文件 /** * 自定义backgroundPosition的animate,支持火狐,jQuery1.8以上版本 * @author Meleong * v1.00 */ ...
- 浏览器exp使用经验
0x00背景 windows平台下,浏览器安全是绕不过的话题,其涉及的安全问题涵盖二进制和web,攻击场景也非常多样化: 用户点击攻击者的恶意URL链接被感染恶意代码 访问恶意站点被绕过同源策略窃取c ...
- How to use php serialize() and unserialize()
A PHP array or object or other complex data structure cannot be transported or stored or otherwise u ...
- Linux终端快捷操作汇总
定位单词 在长段的命令中,使用 Ctrl + ← 和 Ctrl + → 可快速将光标定位到命令中单词的首字母或末尾,实现在各单词之间的快速跳动定位. 你可以试着在终端中输入 apt-get insta ...
- Weex-语法笔记 一
p.p1 { margin: 0.0px 0.0px 2.0px 0.0px; font: 14.0px "PingFang SC Semibold"; color: #45454 ...
- win10系统 L2TP连接尝试失败:ERROR因为安全层在初始化与远程计算机的协商时遇到了一个处理错误
1 确保IPsec Policy Agent服务已启动 2 确保路由和远程访问(Routing and Remote Access)和远程访问连接管理器服务(Remote Access Connect ...