简单叙述一下MYSQL的优化


Posted in 面试题 onMay 09, 2016
1.数据库的设计
尽量把数据库设计的更小的占磁盘空间.
1).尽可能使用更小的整数类型.(mediumint就比int更合适).
2).尽可能的定义字段为not null,除非这个字段需要null.
3).如果没有用到变长字段的话比如varchar,那就采用固定大小的纪录格式比如char.
4).表的主索引应该尽可能的短.这样的话每条纪录都有名字标志且更高效.
5).只创建确实需要的索引。索引有利于检索记录,但是不利于快速保存记录。如果总是要在表的组合字段上做搜索,那么就在这些字段上创建索引。索引的第一部分必须是最常使用的字段.如果总是需要用到很多字段,首先就应该多复制这些字段,使索引更好的压缩。
6).所有数据都得在保存到数据库前进行处理。
7).所有字段都得有默认值。
8).在某些情况下,把一个频繁扫描的表分成两个速度会快好多。在对动态格式表扫描以取得相关记录时,它可能使用更小的静态格式表的情况下更是如此。
2.系统的用途
1).尽量使用长连接.
2).explain 复杂的SQL语句。
3).如果两个关联表要做比较话,做比较的字段必须类型和长度都一致.
4).LIMIT语句尽量要跟order by或者 distinct.这样可以避免做一次full table scan.
5).如果想要清空表的所有纪录,建议用truncate table tablename而不是delete from tablename.
6).能使用STORE PROCEDURE 或者 USER FUNCTION的时候.
7).在一条insert语句中采用多重纪录插入格式.而且使用load data infile来导入大量数据,这比单纯的indert快好多.
8).经常OPTIMIZE TABLE 来整理碎片.
9).还有就是date 类型的数据如果频繁要做比较的话尽量保存在unsigned int 类型比较快。
3.系统的瓶颈
1).磁盘搜索.
并行搜索,把数据分开存放到多个磁盘中,这样能加快搜索时间.
2).磁盘读写(IO)
可以从多个媒介中并行的读取数据。
3).CPU周期
数据存放在主内存中.这样就得增加CPU的个数来处理这些数据。
4).内存带宽
当CPU要将更多的数据存放到CPU的缓存中来的话,内存的带宽就成了瓶颈.

Tags in this post...

面试题 相关文章推荐
请描述一下”is a”关系和”has a”关系
Feb 03 面试题
如何向接受结构参数的函数传入常数值
Feb 17 面试题
iostream与iostream.h的区别
Jan 16 面试题
shallow copy和deep copy的区别
May 09 面试题
介绍一下木马病毒的种类
Jul 26 面试题
编程实现去掉XML的重复结点
May 28 面试题
软件缺陷的分类都有哪些
Aug 22 面试题
为什么需要版本控制
Oct 28 面试题
EJB timer的种类
Oct 28 面试题
史上最全面的Java面试题汇总!
Feb 03 面试题
shell程序如何生命变量?shell变量是弱变量吗?
Nov 10 面试题
SOA面试题:如何在SOA中实现松耦合
Jul 21 面试题
MySQL面试题目集锦
Apr 14 #面试题
如何提高MySql的安全性
Jun 19 #面试题
介绍一下Mysql的存储引擎
Feb 12 #面试题
介绍一下如何优化MySql
Dec 20 #面试题
腾讯公司的一个sql题
Jan 22 #面试题
十一个高级MySql面试题
Oct 06 #面试题
遇到的Mysql的面试题
Jun 29 #面试题
You might like
无数据库的详细域名查询程序PHP版(3)
2006/10/09 PHP
php MYSQL 数据备份类
2009/06/19 PHP
php木马webshell扫描器代码
2012/01/25 PHP
PHP简洁函数(PHP简单明了函数语法)
2012/06/10 PHP
php mysql_real_escape_string addslashes及mysql绑定参数防SQL注入攻击
2016/12/23 PHP
JavaScript 对象模型 执行模型
2010/10/15 Javascript
select、radio表单回显功能实现避免使用jquery载入赋值
2013/06/08 Javascript
详解jquery uploadify 上传文件
2013/11/09 Javascript
把文本中的URL地址转换为可点击链接的JavaScript、PHP自定义函数
2014/07/29 Javascript
javascript获取重复次数最多的字符
2015/07/08 Javascript
JS基础随笔(菜鸟必看篇)
2016/07/13 Javascript
如何提高Dom访问速度
2017/01/05 Javascript
JavaScript变量作用域_动力节点Java学院整理
2017/06/27 Javascript
jquery获取transform里的值实现方法
2017/12/12 jQuery
JS实现将链接生成二维码并转为图片的方法
2018/03/17 Javascript
JavaScript类的继承方法小结【组合继承分析】
2018/07/11 Javascript
vue项目中运用webpack动态配置打包多种环境域名的方法
2019/06/24 Javascript
详解基于element的区间选择组件校验(交易金额)
2021/01/07 Javascript
[05:17]DOTA2睡衣妹卖萌求签名 CJ第二天全明星影像
2013/07/28 DOTA
详细介绍Python中的偏函数
2015/04/27 Python
使用Python抓取豆瓣影评数据的方法
2018/10/17 Python
Python补齐字符串长度的实例
2018/11/15 Python
24式加速你的Python(小结)
2019/06/13 Python
Django的models模型的具体使用
2019/07/15 Python
python系列 文件操作的代码
2019/10/06 Python
基于python+selenium的二次封装的实现
2020/01/06 Python
python实现扑克牌交互式界面发牌程序
2020/04/22 Python
python中读入二维csv格式的表格方法详解(以元组/列表形式表示)
2020/04/24 Python
浅谈django 重载str 方法
2020/05/19 Python
Ego Shoes官网:英国时髦鞋类品牌
2020/10/19 全球购物
如何将字串String转换成整数int
2015/02/21 面试题
学校司机岗位职责
2013/11/14 职场文书
爱情保证书范文
2014/02/01 职场文书
企业安全生产目标责任书
2014/07/23 职场文书
css3实现的加载动画效果
2021/04/07 HTML / CSS
windows server2012 R2下安装PaddleOCR服务的的详细步骤
2022/09/23 Servers