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

面试题 相关文章推荐
使用useBean标志初始化BEAN时如何接受初始化参数
Feb 11 面试题
Java 中访问数据库的步骤?Statement 和PreparedStatement 之间的区别?
Jun 05 面试题
方法名是否可以与构造器的名字相同
Jun 04 面试题
main 主函数执行完毕后,是否可能会再执行一段代码,给出说明
Dec 05 面试题
普天C++笔试题
Mar 20 面试题
SQL Server提供的3种恢复模型都是什么? 有什么区别?
May 13 面试题
SQL Server 2000数据库的文件有哪些,分别进行描述。
Nov 09 面试题
请解释virtual关键字的含义
Jun 17 面试题
垃圾回收的优点和原理
May 16 面试题
初级Java程序员面试题
Mar 03 面试题
Java模拟试题
Nov 10 面试题
送给程序员的20个Java集合面试问题
Aug 06 面试题
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用GD库生成高质量的缩略图片
2011/03/09 PHP
php批量上传的实现代码
2013/06/09 PHP
thinkPHP使用pclzip打包备份mysql数据库的方法
2016/04/30 PHP
PHP通过引用传递参数用法分析
2016/12/01 PHP
javascript数字数组去重复项的实现代码
2010/12/30 Javascript
js获取时间(本周、本季度、本月..)
2013/11/22 Javascript
js判断客户端是iOS还是Android等移动终端的方法
2013/12/11 Javascript
node.js中的fs.writeFileSync方法使用说明
2014/12/14 Javascript
浅谈javascript 函数内部属性
2015/01/21 Javascript
jQuery中ajax的load()与post()方法实例详解
2016/01/05 Javascript
js采用concat和sort将N个数组拼接起来的方法
2016/01/21 Javascript
Backbone.js框架中简单的View视图编写学习笔记
2016/02/14 Javascript
confirm确认对话框的实现方法总结
2016/06/17 Javascript
深入理解bootstrap框架之入门准备
2016/10/09 Javascript
js编写三级联动简单案例
2016/12/21 Javascript
bootstrap laydate日期组件使用详解
2017/01/04 Javascript
详解小程序中h5页面onShow实现及跨页面通信方案
2019/05/30 Javascript
js实现随机div颜色位置 类似满天星效果
2019/10/24 Javascript
原生javascript的ajax请求及后台PHP响应操作示例
2020/02/24 Javascript
[02:51]DOTA2英雄基础教程 艾欧
2014/01/13 DOTA
[45:18]2018DOTA2亚洲邀请赛 4.3 突围赛 Optic vs iG 第一场
2018/04/04 DOTA
Python字符串格式化的方法(两种)
2017/09/19 Python
在pycharm中设置显示行数的方法
2019/01/16 Python
Python 图像对比度增强的几种方法(小结)
2019/09/25 Python
英国游戏机和游戏购物网站:365games.co.uk
2018/06/18 全球购物
Tea Collection官网:一家位于旧金山的童装公司
2020/08/07 全球购物
下列程序在32位linux或unix中的结果是什么
2015/01/26 面试题
端午节活动策划方案
2014/03/09 职场文书
代理协议书范本
2014/04/22 职场文书
2014年社会实践活动总结范文
2014/04/29 职场文书
2014年销售工作总结范文
2014/12/01 职场文书
公司车辆管理制度
2015/08/04 职场文书
《社戏》教学反思
2016/02/22 职场文书
长辈生日祝福语大全(72句)
2019/08/09 职场文书
详解MySQL事务的隔离级别与MVCC
2021/04/22 MySQL
vue-cropper组件实现图片切割上传
2021/05/27 Vue.js