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

面试题 相关文章推荐
PHP如何调用MYSQL存储过程
May 30 面试题
Sony C++笔试题
Mar 10 面试题
如何查询Oracle数据库中已经创建的索引
Oct 11 面试题
如何理解委托
Jan 06 面试题
Linux如何为某个操作添加别名
Mar 01 面试题
分别介绍一下Session Bean和Entity Bean
Mar 13 面试题
说说在weblogic中开发消息Bean时的persistent与non-persisten的差别
Apr 07 面试题
介绍一下mysql的日期和时间函数
Mar 28 面试题
MVC的各个部分都有那些技术来实现?如何实现?
Apr 21 面试题
JAVA高级程序员面试题
Sep 06 面试题
描述JSP和Servlet的区别、共同点、各自应用的范围
Oct 02 面试题
什么是servlet
May 08 面试题
MySQL面试题目集锦
Apr 14 #面试题
如何提高MySql的安全性
Jun 19 #面试题
介绍一下Mysql的存储引擎
Feb 12 #面试题
介绍一下如何优化MySql
Dec 20 #面试题
腾讯公司的一个sql题
Jan 22 #面试题
十一个高级MySql面试题
Oct 06 #面试题
遇到的Mysql的面试题
Jun 29 #面试题
You might like
预告映像公开!第1章续篇剧场版动画《Princess Principal Crown Handler》4月10日上映!
2020/03/06 日漫
用windows下编译过的eAccelerator for PHP 5.1.6实现php加速的使用方法
2007/09/30 PHP
如何让搜索引擎抓取AJAX内容解决方案
2014/08/25 PHP
php使用cookie显示用户上次访问网站日期的方法
2015/01/26 PHP
JQuery index()方法使用代码
2010/06/02 Javascript
JavaScript编程开发中的五个实用小技巧
2010/07/22 Javascript
在JavaScript中获取请求的URL参数[正则]
2010/12/25 Javascript
jquery高效反选具体实现
2013/05/05 Javascript
AngularJS模块管理问题的非常规处理方法
2015/04/29 Javascript
jQuery实现下拉框选择图片功能实例
2015/08/08 Javascript
jquery实现隐藏在左侧的弹性弹出菜单效果
2015/09/18 Javascript
基于jQuery实现仿搜狐辩论投票动画代码(附源码下载)
2016/02/18 Javascript
ionic3 懒加载
2017/08/16 Javascript
解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题
2018/08/03 Javascript
浅析Vue实例以及生命周期
2018/08/14 Javascript
Layui 设置select下拉框自动选中某项的方法
2018/08/14 Javascript
微信小程序实现动态显示和隐藏某个控件功能示例
2018/12/14 Javascript
微信小程序时间选择插件使用详解
2018/12/28 Javascript
vue页面加载时的进度条功能(实例代码)
2020/01/13 Javascript
js实现无刷新监听URL的变化示例代码详解
2020/06/03 Javascript
详解ES6 扩展运算符的使用与注意事项
2020/11/12 Javascript
[48:26]VGJ.S vs infamous Supermajor 败者组 BO3 第二场 6.4
2018/06/05 DOTA
[02:21]十步杀一人,千里不留行——DOTA2全新英雄天涯墨客展示
2018/08/29 DOTA
Python ZipFile模块详解
2013/11/01 Python
浅谈scrapy 的基本命令介绍
2017/06/13 Python
django开发教程之利用缓存文件进行页面缓存的方法
2017/11/10 Python
Python中__slots__属性介绍与基本使用方法
2018/09/05 Python
在Python中,不用while和for循环遍历列表的实例
2019/02/20 Python
Python基于WordCloud制作词云图
2019/11/29 Python
opencv python如何实现图像二值化
2020/02/03 Python
五星级酒店餐饮部总监的标准岗位职责
2014/02/17 职场文书
公司委托书格式
2014/08/01 职场文书
保安辞职信范文
2015/02/28 职场文书
2015年乡镇工会工作总结
2015/05/19 职场文书
2016年6.5世界环境日宣传活动总结
2016/04/01 职场文书
八年级作文之感恩
2019/11/22 职场文书