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

面试题 相关文章推荐
Java工程师面试集锦之Spring框架
Jun 16 面试题
C/C++有关内存的思考题
Dec 04 面试题
东方通信股份有限公司VC面试题
Aug 27 面试题
数据库基础的一些面试题
Feb 25 面试题
2019史上最全Database工程师题库
Dec 06 面试题
Windows和Linux动态库应用异同
Apr 17 面试题
Linux如何压缩可执行文件
Oct 21 面试题
配置管理计划的主要内容有哪些
Jun 20 面试题
EJB的基本架构
Sep 22 面试题
String、StringBuffer、StringBuilder有区别
Sep 18 面试题
Java面试笔试题大全
Nov 23 面试题
这76道Java面试题及答案,祝你能成功通过面试
Apr 16 面试题
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应用程序来获取Web服务器的状态信息
2006/10/09 PHP
PHP安装攻略:常见问题解答(一)
2006/10/09 PHP
关于查看MSSQL 数据库 用户每个表 占用的空间大小
2013/06/21 PHP
php快速排序原理与实现方法分析
2016/05/26 PHP
在laravel中使用Symfony的Crawler组件分析HTML
2017/06/19 PHP
也说JavaScript中String类的replace函数
2011/09/22 Javascript
window.opener用法和用途实例介绍
2013/08/19 Javascript
基于JavaScript实现简单的随机抽奖小程序
2016/01/05 Javascript
JS常见简单正则表达式验证功能小结【手机,地址,企业税号,金额,身份证等】
2017/01/22 Javascript
canvas实现十二星座星空图
2017/02/14 Javascript
JSON与js对象序列化实例详解
2017/03/16 Javascript
Vue 表情包输入组件的实现代码
2019/01/21 Javascript
微信小程序之滑动页面隐藏和显示组件功能的实现代码
2020/06/19 Javascript
[03:10]超级美酒第四天 fy拉比克秀 大合集
2018/06/05 DOTA
Python字典操作简明总结
2015/04/13 Python
python用10行代码实现对黄色图片的检测功能
2015/08/10 Python
Python弹出输入框并获取输入值的实例
2019/06/18 Python
python3 自动识别usb连接状态,即对usb重连的判断方法
2019/07/03 Python
基于pytorch的lstm参数使用详解
2020/01/14 Python
Python telnet登陆功能实现代码
2020/04/16 Python
Python基于numpy模块实现回归预测
2020/05/14 Python
Python实现简单猜数字游戏
2021/02/03 Python
HTML5图片预览实例分享
2014/06/04 HTML / CSS
使用HTML5进行SVG矢量图形绘制的入门教程
2016/02/19 HTML / CSS
Melissa鞋马来西亚官方网站:MDreams马来西亚
2018/04/05 全球购物
P D PAOLA法国官网:西班牙著名的珠宝首饰品牌
2020/02/15 全球购物
Kickers鞋英国官网:男士、女士和儿童鞋
2021/03/08 全球购物
企业标语大全
2014/07/01 职场文书
优秀共产党员推荐材料
2014/12/18 职场文书
求职自我评价范文
2015/03/09 职场文书
会计入职心得体会
2016/01/22 职场文书
2016年优秀党务工作者先进事迹材料
2016/02/29 职场文书
详解PHP Swoole与TCP三次握手
2021/05/27 PHP
详解缓存穿透击穿雪崩解决方案
2021/05/28 Redis
利用python做数据拟合详情
2021/11/17 Python
mysql数据库隔离级别详解
2022/06/16 MySQL