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

面试题 相关文章推荐
C语言怎样定义和声明全局变量和函数最好
Nov 26 面试题
C/C++有关内存的思考题
Dec 04 面试题
枚举和一组预处理的#define有什么不同
Sep 21 面试题
数据库基础的一些面试题
Feb 25 面试题
存储过程和sql语句的优缺点
Jul 02 面试题
南京软件公司的.net程序员笔试题
Aug 31 面试题
金士达面试非笔试
Mar 14 面试题
P/Invoke是什么
Jul 31 面试题
Python面试题:如何用Python来发送邮件
Mar 15 面试题
swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
Mar 30 面试题
若干个Java基础面试题
May 19 面试题
什么是ESB?请介绍一下ESB?
May 27 面试题
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一些服务器端特性的配置加强php的安全
2006/10/09 PHP
php daodb插入、更新与删除数据
2009/03/19 PHP
php将数据库中所有内容生成静态html文档的代码
2010/04/12 PHP
基于PHP生成静态页的实现方法
2013/05/10 PHP
php使用imagick模块实现图片缩放、裁剪、压缩示例
2014/04/17 PHP
ThinkPHP之A方法实例讲解
2014/06/20 PHP
ThinkPHP模板中数组循环实例
2014/10/30 PHP
浅谈Laravel模板实体转义带来的坑
2019/10/22 PHP
禁止F5等快捷键的JS代码
2007/03/06 Javascript
ExtJS 工具栏 分页事件参数
2010/03/05 Javascript
JavaScript 格式字符串的应用
2010/03/29 Javascript
javascript根据像素点取位置示例
2014/01/27 Javascript
通过遮罩层实现浮层DIV登录的js代码
2014/02/07 Javascript
jquery text()方法取标签中的文本
2014/07/25 Javascript
深入了解Node.js中的一些特性
2014/09/25 Javascript
ECMAScript 6即将带给我们新的数组操作方法前瞻
2015/01/06 Javascript
jQuery中innerWidth()方法用法实例
2015/01/19 Javascript
基于jquery ui的alert,confirm方案(支持换肤)
2015/04/03 Javascript
JavaScript的jQuery库中function的存在和参数问题
2015/08/13 Javascript
JS实现拖动滚动条评分的效果代码分享
2016/09/29 Javascript
js/jq仿window文件夹移动/剪切/复制等操作代码
2017/03/08 Javascript
iscroll实现下拉刷新功能
2017/07/18 Javascript
移动端图片上传旋转、压缩问题的方法
2018/10/16 Javascript
在Vue中创建可重用的 Transition的方法
2020/06/02 Javascript
[51:06]2018DOTA2亚洲邀请赛3月29日 小组赛A组 KG VS Liquid
2018/03/30 DOTA
python统计日志ip访问数的方法
2015/07/06 Python
使用Python进行二进制文件读写的简单方法(推荐)
2016/09/12 Python
python中with用法讲解
2020/02/07 Python
python 绘制正态曲线的示例
2020/09/24 Python
深入浅出CSS3 background-clip,background-origin和border-image教程
2011/01/27 HTML / CSS
HTML5中的进度条progress元素简介及兼容性处理
2016/06/02 HTML / CSS
Hawes & Curtis官网:英国经典品牌
2019/07/27 全球购物
CAD制图设计师自荐信
2014/01/29 职场文书
工程负责人任命书
2014/06/06 职场文书
护士节慰问信
2015/02/15 职场文书
干部考核工作总结2015
2015/07/24 职场文书