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

面试题 相关文章推荐
String这个类型的class为何定义成final?
Nov 13 面试题
Java里面StringBuilder和StringBuffer有什么区别
Jun 06 面试题
Java工程师面试集锦之Spring框架
Jun 16 面试题
C语言中一个结构不能包含指向自己的指针吗
May 25 面试题
简述数组与指针的区别
Jan 02 面试题
你对IPv6了解程度
Feb 09 面试题
C#怎么让一个窗口居中显示?
Oct 20 面试题
linux面试题参考答案(3)
Sep 13 面试题
Shell编程面试题
May 30 面试题
介绍一下UNIX启动过程
Nov 14 面试题
如何理解transaction事务的概念
May 27 面试题
北京捷通华声语音技术有限公司Java软件工程师笔试题
Apr 10 面试题
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中的按位与和按位或操作示例
2014/01/27 PHP
既简单又安全的PHP验证码 附调用方法
2016/06/02 PHP
PHP5.4起内置web服务器使用方法
2016/08/09 PHP
用js计算页面执行时间的函数
2006/12/07 Javascript
解决使用attachEvent函数时,this指向被绑定的元素的问题的方法
2007/08/13 Javascript
COM中获取JavaScript数组大小的代码
2009/11/22 Javascript
Ext对基本类型的扩展 ext,extjs,format
2010/12/25 Javascript
控制台报错object is not a function的解决方法
2014/08/24 Javascript
jQuery元素选择器用法实例
2014/12/23 Javascript
jQuery实现的Div窗口震动效果实例
2015/08/07 Javascript
JS实现的简洁纵向滑动菜单(滑动门)效果
2015/10/19 Javascript
Javascript将JSON日期格式化
2016/08/23 Javascript
详解Vue自定义过滤器的实现
2017/01/10 Javascript
JavaScrpt判断一个数是否是质数的实例代码
2017/06/11 Javascript
vue实现商城购物车功能
2017/11/27 Javascript
详解Javascript中new()到底做了些什么?
2018/03/29 Javascript
JavaScript文本特效实例小结【3个示例】
2018/12/22 Javascript
浅谈Vue3.0之前你必须知道的TypeScript实战技巧
2019/09/11 Javascript
让mocha支持ES6模块的方法实现
2020/01/14 Javascript
JavaScript实现公告栏上下滚动效果
2020/03/13 Javascript
es6数组的flat(),flatMap()函数用法实例分析
2020/04/18 Javascript
在Python中使用itertools模块中的组合函数的教程
2015/04/13 Python
详解Python中的type()方法的使用
2015/05/21 Python
Python实现Linux中的du命令
2017/06/12 Python
python3操作mysql数据库的方法
2017/06/23 Python
Python格式化日期时间操作示例
2018/06/28 Python
在Pycharm中调试Django项目程序的操作方法
2019/07/17 Python
Python facenet进行人脸识别测试过程解析
2019/08/16 Python
pytorch在fintune时将sequential中的层输出方法,以vgg为例
2019/08/20 Python
Python 窗体(tkinter)下拉列表框(Combobox)实例
2020/03/04 Python
详解python使用金山词霸的翻译功能(调试工具断点的使用)
2021/01/07 Python
GEOX鞋美国官方网站:意大利会呼吸的鞋
2017/07/12 全球购物
联想瑞士官方网站:Lenovo Switzerland
2017/11/19 全球购物
小学生自我评价范例
2013/09/24 职场文书
施工安全协议书范本
2014/09/26 职场文书
python标准库ElementTree处理xml
2022/05/20 Python