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

面试题 相关文章推荐
一套VC试题
Jan 23 面试题
华为c/c++笔试题
Jan 25 面试题
struct与class的区别
Feb 03 面试题
编写类String 的构造函数、析构函数和赋值函数
Sep 09 面试题
什么是.net的Remoting技术
Jul 08 面试题
傲盾软件面试题
Aug 17 面试题
接口可以包含哪些成员
Sep 30 面试题
linux比较文件内容的命令是什么
Sep 23 面试题
介绍一下write命令
Sep 24 面试题
用Java语言将一个键盘输入的数字转化成中文输出
Jan 25 面试题
Java中的类包括什么内容?设计时要注意哪些方面
May 23 面试题
Java中各种基本数据类型的默认值都是什么
Dec 22 面试题
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实现桥梁模式(bridge)
2015/12/07 PHP
php使用gearman进行任务分发操作实例详解
2020/02/26 PHP
关于vue.js弹窗组件的知识点总结
2016/09/11 Javascript
Easyui的组合框的取值与赋值
2016/10/28 Javascript
JavaScript函数节流和函数防抖之间的区别
2017/02/15 Javascript
bootstrap为水平排列的表单和内联表单设置可选的图标
2017/02/15 Javascript
JS匹配日期和时间的正则表达式示例
2017/05/12 Javascript
关于javascript sort()排序你可能忽略的一点理解
2017/07/18 Javascript
js数字滑动时钟的简单实现(示例讲解)
2017/08/14 Javascript
基于VUE.JS的移动端框架Mint UI的使用
2017/10/11 Javascript
OkHttp踩坑随笔为何 response.body().string() 只能调用一次
2018/01/08 Javascript
node.js+express+mySQL+ejs+bootstrop实现网站登录注册功能
2018/01/12 Javascript
Nuxt.js实战详解
2018/01/18 Javascript
JS中offset和匀速动画详解
2018/02/06 Javascript
一文了解vue-router之hash模式和history模式
2019/05/31 Javascript
VUE 组件转换为微信小程序组件的方法
2019/11/06 Javascript
微信小程序点击生成朋友圈分享图(遇到的坑)
2020/06/17 Javascript
python简单实例训练(21~30)
2017/11/15 Python
Python检测数据类型的方法总结
2019/05/20 Python
Python任意字符串转16, 32, 64进制的方法
2019/06/12 Python
python中for循环把字符串或者字典添加到列表的方法
2019/07/20 Python
Django在admin后台集成TinyMCE富文本编辑器的例子
2019/08/09 Python
详解numpy矩阵的创建与数据类型
2019/10/18 Python
基于matplotlib xticks用法详解
2020/04/16 Python
Boutique 1美国:阿联酋奢侈时尚零售商
2017/10/16 全球购物
全球500多个机场的接送服务:Suntransfers
2019/06/03 全球购物
中级会计大学生职业生涯规划书
2014/09/16 职场文书
创建文明城市倡议书
2015/04/28 职场文书
婚庆公司开业主持词
2015/06/30 职场文书
防溺水安全教育主题班会
2015/08/12 职场文书
婚礼男方父母答谢词
2015/09/29 职场文书
2019企业给员工的慰问信
2019/06/24 职场文书
2019年大学生暑期社会实践调查报告模板
2019/11/07 职场文书
python实现黄金分割法的示例代码
2021/04/28 Python
redis中lua脚本使用教程
2021/11/01 Redis
Windows Server 2019 配置远程控制以及管理方法
2022/04/28 Servers