简单叙述一下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面试题及答案二
May 23 面试题
JSF如何进行表格处理及取值
Aug 06 面试题
Java的基础面试题附答案
Jan 10 面试题
我有一个char * 型指针正巧指向一些int 型变量, 我想跳过它们。 为什么如下的代码((int *)p)++; 不行?
May 09 面试题
"火柴棍式"程序员面试题
Mar 16 面试题
汇智创新科技发展有限公司
Dec 06 面试题
南京某公司笔试题
Jan 27 面试题
抽象类和接口的区别
Sep 19 面试题
在c#中using和new这两个关键字有什么意义
May 19 面试题
构造方法和其他方法的区别
Apr 26 面试题
几个判断型的面试题
Jul 03 面试题
UNIX命令速查表
Mar 10 面试题
MySQL面试题目集锦
Apr 14 #面试题
如何提高MySql的安全性
Jun 19 #面试题
介绍一下Mysql的存储引擎
Feb 12 #面试题
介绍一下如何优化MySql
Dec 20 #面试题
腾讯公司的一个sql题
Jan 22 #面试题
十一个高级MySql面试题
Oct 06 #面试题
遇到的Mysql的面试题
Jun 29 #面试题
You might like
Protoss魔法科技
2020/03/14 星际争霸
PHP脚本的10个技巧(2)
2006/10/09 PHP
php中文字母数字验证码实现代码
2008/04/25 PHP
PHP 的ArrayAccess接口 像数组一样来访问你的PHP对象
2010/10/12 PHP
PHP操作数组的一些函数整理介绍
2011/07/17 PHP
主流PHP框架的优缺点对比分析
2014/12/25 PHP
支持汉转拼和拼音分词的PHP中文工具类ChineseUtil
2018/02/23 PHP
用javascript将数据库中的TEXT类型数据动态赋值到TEXTAREA中
2007/04/20 Javascript
javascript常见用法总结
2014/05/22 Javascript
window.onload使用指南
2015/09/13 Javascript
JavaScript如何调试有哪些建议和技巧附五款有用的调试工具
2015/10/28 Javascript
jQuery获取cookie值及删除cookie用法实例
2016/04/15 Javascript
用js实现简单算法的实例代码
2016/09/24 Javascript
vue2.0+webpack环境的构造过程
2016/11/08 Javascript
angular或者js怎么确定选中ul中的哪几个li
2017/08/16 Javascript
vue生成文件本地打开查看效果的实例
2018/09/06 Javascript
vue实现短信验证码登录功能(流程详解)
2019/12/10 Javascript
解决vue中的无限循环问题
2020/07/27 Javascript
[00:02]DOTA2新版本使用PA至宝后暴击展示
2014/11/19 DOTA
[02:24]DOTA2亚洲邀请赛 NAVI战队出场宣传片
2015/02/07 DOTA
[47:52]完美世界DOTA2联赛PWL S2 PXG vs InkIce 第二场 11.26
2020/11/30 DOTA
python安装oracle扩展及数据库连接方法
2017/02/21 Python
Ubuntu 下 vim 搭建python 环境 配置
2017/06/12 Python
Flask-WTF表单的使用方法
2019/07/12 Python
Django后端接收嵌套Json数据及解析详解
2019/07/17 Python
Django 批量插入数据的实现方法
2020/01/12 Python
英国复古皮包品牌:Beara Beara
2018/07/18 全球购物
C语言怎样定义和声明全局变量和函数最好
2013/11/26 面试题
Linux管理员面试经常问道的相关命令
2013/04/29 面试题
英语专业学生个人求职信范文
2014/01/06 职场文书
医务工作者先进事迹材料
2014/01/26 职场文书
说谎欺骗人检讨书300字
2014/11/18 职场文书
旷工检讨书大全
2015/08/15 职场文书
入伍志愿书怎么写?
2019/07/19 职场文书
JavaScript事件的委托(代理)的用法示例详解
2022/02/18 Javascript
PostgreSQL出现死锁该如何解决
2022/05/30 PostgreSQL