简单叙述一下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...

面试题 相关文章推荐
以下为Windows NT 下的32 位C++程序,请计算sizeof 的值
Dec 07 面试题
使用索引有什么好处
Jul 27 面试题
简述索引存取方法的作用和建立索引的原则
Mar 26 面试题
亿阳信通股份有限公司笔试题(C#)
Mar 04 面试题
盛大笔试题
Nov 05 面试题
C#软件工程师英语面试题
Jun 07 面试题
Linux管理员面试题 Linux admin interview questions
Jul 08 面试题
性能测试工程师的面试题
Feb 20 面试题
short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
Sep 26 面试题
JSF界面控制层技术
Jun 17 面试题
为什么要使用servlet
Jan 17 面试题
ruby如何进行集成操作?Ruby能进行多重继承吗?
Oct 16 面试题
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 Mysql类 可以参考学习熟悉下
2009/06/21 PHP
javascript some()函数用法详解
2014/11/13 PHP
ThinkPHP框架设计及扩展详解
2014/11/25 PHP
php判断数组中是否存在指定键(key)的方法
2015/03/17 PHP
搭建基于Docker的PHP开发环境的详细教程
2015/07/01 PHP
详解php中serialize()和unserialize()函数
2017/07/08 PHP
JS 的应用开发初探(mootools)
2009/12/19 Javascript
Javascript图像处理—平滑处理实现原理
2012/12/28 Javascript
Jquery实现弹出层分享微博插件具备动画效果
2013/04/03 Javascript
JavaScript数组深拷贝和浅拷贝的两种方法
2014/04/16 Javascript
JS获取下拉框显示值和判断单选按钮的方法
2015/07/09 Javascript
jQuery动画效果实现图片无缝连续滚动
2016/01/12 Javascript
jQuery ready()和onload的加载耗时分析
2016/09/08 Javascript
JavaScript面向对象精要(下部)
2017/09/12 Javascript
详解vue项目打包后通过百度的BAE发布到网上的流程
2018/03/05 Javascript
简述JS浏览器的三种弹窗
2018/07/15 Javascript
jQuery HTML css()方法与css类实例详解
2020/05/20 jQuery
[42:32]DOTA2上海特级锦标赛B组资格赛#2 Fnatic VS Spirit第二局
2016/02/27 DOTA
Python探索之pLSA实现代码
2017/10/25 Python
python爬虫 基于requests模块的get请求实现详解
2019/08/20 Python
python中有帮助函数吗
2020/06/19 Python
Django Form设置文本框为readonly操作
2020/07/03 Python
详解Python直接赋值,深拷贝和浅拷贝
2020/07/09 Python
python实现跨年表白神器--你值得拥有
2021/01/04 Python
你不知道的葡萄干处理法、橙蜜处理法、二氧化碳酵母法
2021/03/17 冲泡冲煮
使用CSS3设计地图上的雷达定位提示效果
2016/04/05 HTML / CSS
整理的15个非常有用的 HTML5 开发教程和速查手册
2011/10/18 HTML / CSS
某公司.Net方向面试题
2014/04/24 面试题
EJB的角色和三个对象
2015/12/31 面试题
四种会话跟踪技术
2015/05/20 面试题
竞聘上岗演讲稿范文
2014/01/10 职场文书
师德师风的心得体会
2014/09/02 职场文书
计划生育个人总结
2015/03/02 职场文书
2015年建筑工程工作总结
2015/05/13 职场文书
Python实战之疫苗研发情况可视化
2021/05/18 Python
ubuntu下常用apt命令介绍
2022/06/05 Servers