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

面试题 相关文章推荐
如何在Cookie里面保存Unicode和国际化字符
May 25 面试题
用你熟悉的语言写一个连接ORACLE数据库的程序,能够完成修改和查询工作
Jun 11 面试题
C语言编程练习
Apr 02 面试题
武汉瑞得软件笔试题
Oct 27 面试题
extern是什么意思
Mar 10 面试题
常用UNIX 命令(Linux的常用命令)
Jul 10 面试题
介绍一下gcc特性
Oct 31 面试题
linux面试题参考答案(10)
Nov 04 面试题
EJB发布WEB服务一般步骤
Oct 31 面试题
Java编程面试题
Apr 04 面试题
怎样在 Applet 中建立自己的菜单(MenuBar/Menu)?
Jun 20 面试题
类的返射机制中的包及核心类
Sep 12 面试题
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中字符串长度的截取用法示例
2017/01/12 PHP
php web环境和命令行环境下查找php.ini的位置
2019/07/17 PHP
javascript之函数直接量(function(){})()
2007/06/29 Javascript
Javascript结合css实现网页换肤功能
2009/11/02 Javascript
jQuery Validation插件remote验证方式的Bug解决
2010/07/01 Javascript
jquery判断checkbox(复选框)是否被选中的代码
2010/10/20 Javascript
js实现的标题栏新消息闪烁提示效果
2014/06/06 Javascript
Visual Studio中js调试的方法图解
2014/06/30 Javascript
js+jquery实现图片裁剪功能
2015/01/02 Javascript
jQuery树形下拉菜单特效代码分享
2015/08/15 Javascript
JS模拟并美化的表单控件完整实例
2015/08/19 Javascript
Vue.js基础知识汇总
2016/04/27 Javascript
JS从数组中随机取出几个数组元素的方法
2016/08/02 Javascript
Bootstrap面板使用方法
2017/01/16 Javascript
动态加载css方法实现和深入解析
2017/01/18 Javascript
javascript实现复选框全选或反选
2017/02/04 Javascript
AngularJS对动态增加的DOM实现ng-keyup事件示例
2018/03/12 Javascript
微信小程序有旋转动画效果的音乐组件实例代码
2018/08/22 Javascript
详解基于electron制作一个node压缩图片的桌面应用
2019/01/29 Javascript
跟混乱的页面弹窗说再见
2019/04/11 Javascript
使用webpack将ES6转化ES5的实现方法
2019/10/13 Javascript
浏览器JavaScript调试功能无法使用解决方案
2020/09/18 Javascript
Python中循环引用(import)失败的解决方法
2018/04/22 Python
Django Docker容器化部署之Django-Docker本地部署
2019/10/09 Python
PyTorch实现ResNet50、ResNet101和ResNet152示例
2020/01/14 Python
Python实现查找数据库最接近的数据
2020/06/08 Python
Mio Skincare中文官网:肌肤和身体护理
2016/10/26 全球购物
最新大学毕业求职简历的自我评价
2013/10/18 职场文书
体育老师的教学自我评价分享
2013/11/19 职场文书
安全保证书范文
2014/04/29 职场文书
班级标语大全
2014/06/21 职场文书
工厂仓管员岗位职责范本
2014/07/17 职场文书
银行奉献演讲稿
2014/09/16 职场文书
环保守法证明
2015/06/24 职场文书
厉行节约工作总结
2015/08/12 职场文书
SpringBoot2零基础到精通之数据库专项精讲
2022/03/22 Java/Android