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

面试题 相关文章推荐
编码实现字符串转整型的函数
Jun 02 面试题
Android笔试题总结
Nov 29 面试题
几道数据库的概念性面试题
May 30 面试题
阿里巴巴的Oracle DBA笔试题答案-SQL tuning类
Apr 03 面试题
程序员机试试题汇总
Mar 07 面试题
Internal修饰符有什么含义
Jul 10 面试题
Linux操作面试题
Feb 11 面试题
linux系统都有哪些运行级别
Mar 26 面试题
远程调用的原理
Jul 05 面试题
Prototype如何为一个Ajax添加一个参数
Dec 06 面试题
int和Integer有什么区别
May 25 面试题
创联软件面试题笔试题
Oct 07 面试题
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中实现中文字符进制转换原理分析
2011/12/06 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(四)
2014/06/23 PHP
laravel 中某一字段自增、自减的例子
2019/10/11 PHP
laravel 解决路由除了根目录其他都404的问题
2019/10/18 PHP
javascript GUID生成器实现代码
2009/10/31 Javascript
JS获取页面input控件中所有text控件并追加样式属性
2013/02/25 Javascript
javascript函数定义的几种区别小结
2014/01/06 Javascript
javascript数组操作方法小结和3个属性详细介绍
2014/07/05 Javascript
提高NodeJS中SSL服务的性能
2014/07/15 NodeJs
kindeditor修复会替换script内容的问题
2015/04/03 Javascript
Bootstrap每天必学之表单
2015/11/23 Javascript
JS简单设置下拉选择框默认值的方法
2016/08/20 Javascript
浅析vue component 组件使用
2017/03/06 Javascript
vue时间格式化实例代码
2017/06/13 Javascript
Vue项目webpack打包部署到服务器的实例详解
2017/07/17 Javascript
webpack组织模块打包Library的原理及实现
2018/03/10 Javascript
详解微信小程序的不同函数调用的几种方法
2019/05/08 Javascript
简单了解vue中父子组件如何相互传递值(基础向)
2019/07/12 Javascript
Python中的模块和包概念介绍
2015/04/13 Python
Python中datetime模块参考手册
2017/01/13 Python
Python 带有参数的装饰器实例代码详解
2018/12/06 Python
使用python实现mqtt的发布和订阅
2019/05/05 Python
python3+django2开发一个简单的人员管理系统过程详解
2019/07/23 Python
python如何绘制疫情图
2020/09/16 Python
改变 Python 中线程执行顺序的方法
2020/09/24 Python
春秋航空官方网站:Spring Airlines
2017/09/27 全球购物
Bibloo匈牙利:女装、男装、童装及鞋子和配饰
2019/04/14 全球购物
党委班子剖析材料
2014/08/21 职场文书
向国旗敬礼活动小结
2014/09/27 职场文书
党委书记群众路线对照检查材料思想汇报
2014/10/04 职场文书
营业员岗位职责
2015/02/11 职场文书
2015年宣传部工作总结范文
2015/03/31 职场文书
2015年人力资源部工作总结
2015/04/30 职场文书
Python学习开发之图形用户界面详解
2021/08/23 Python
vue选项卡切换的实现案例
2022/04/11 Vue.js
python绘制云雨图raincloud plot
2022/08/05 Python