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

面试题 相关文章推荐
如何打印出当前源文件的文件名以及源文件的当前行号
Apr 05 面试题
WEB控件可以激发服务端事件,请谈谈服务端事件是怎么发生并解释其原理?自动传回是什么?为什么要使用自动传回?
Feb 21 面试题
VLAN和VPN有什么区别?分别实现在OSI的第几层?
Dec 23 面试题
STP的判定过程
Oct 01 面试题
简述使用ftp进行文件传输时的两种登录方式?它们的区别是什么?常用的ftp文件传输命令是什么?
Nov 20 面试题
一些Solaris面试题
Mar 22 面试题
shell程序中如何注释
Feb 17 面试题
外企测试工程师面试题
Feb 01 面试题
How TDD works
Sep 30 面试题
什么是GWT的Entry Point
Aug 16 面试题
介绍一下except的用法和作用
Jan 22 面试题
西安夏日科技有限公司Java笔试题
Jan 11 面试题
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 fckeditor 调用的函数
2009/06/21 PHP
Yii使用DeleteAll连表删除出现报错问题的解决方法
2016/07/14 PHP
js使用post 方式打开新窗口
2015/02/26 Javascript
在其他地方你学不到的jQuery小贴士和技巧(欢迎收藏)
2016/01/20 Javascript
浅析jquery数组删除指定元素的方法:grep()
2016/05/19 Javascript
AngularJS动态绑定HTML的方法分析
2016/11/07 Javascript
微信小程序 require机制详解及实例代码
2016/12/14 Javascript
AngularJS中ng-class用法实例分析
2017/07/06 Javascript
BootStrap入门学习第一篇
2017/08/28 Javascript
微信小程序实现多宫格抽奖活动
2020/04/15 Javascript
vue实现的上传图片到数据库并显示到页面功能示例
2018/03/17 Javascript
解决jquery有正确返回值但不执行success函数的问题
2018/08/20 jQuery
微信小程序视图容器(swiper)组件创建轮播图
2020/06/19 Javascript
vue.js实现二级菜单效果
2019/10/19 Javascript
jQuery实现轮播图效果
2019/11/26 jQuery
NodeJS开发人员常见五个错误理解
2020/10/14 NodeJs
[01:41]DOTA2超级联赛专访YYF 称一辈子难忘TI2
2013/05/28 DOTA
[01:10:24]DOTA2-DPC中国联赛 正赛 VG vs Aster BO3 第一场 2月28日
2021/03/11 DOTA
使用基于Python的Tornado框架的HTTP客户端的教程
2015/04/24 Python
Python中列表的一些基本操作知识汇总
2015/05/20 Python
Python的Django框架下管理站点的基本方法
2015/07/17 Python
Python线程下使用锁的技巧分享
2018/09/13 Python
python+PyQT实现系统桌面时钟
2020/06/16 Python
python 自动批量打开网页的示例
2019/02/21 Python
Python判断字符串是否xx开始或结尾的示例
2019/08/08 Python
python将数组n等分的实例
2019/12/02 Python
Python实现加密接口测试方法步骤详解
2020/06/05 Python
Django与AJAX实现网页动态数据显示的示例代码
2021/02/24 Python
HTML5 Canvas 起步(1) - 基本概念
2009/05/12 HTML / CSS
香蕉共和国Banana Republic官网:美国GAP旗下偏贵族风格服饰品牌
2016/11/21 全球购物
高中生职业生涯规划书
2014/02/24 职场文书
会计电算化应届生自荐信
2014/02/25 职场文书
英语一分钟演讲稿
2014/04/29 职场文书
运动会闭幕式通讯稿
2015/07/18 职场文书
关于运动会的广播稿
2015/08/19 职场文书
JS创建或填充任意长度数组的小技巧汇总
2021/10/24 Javascript