阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL性能优化注意事项以及索引

453次阅读
没有评论

共计 2531 个字符,预计需要花费 7 分钟才能阅读完成。

MySQL 性能优化注意事项以及索引

一:数据库的优化方面
1 商业需求的影响
比如说论坛里的帖子统计,并且实时更新
从功能上来说通过命令  select  count(*)from 表名 可以得到结果,如果论坛每秒产生产生成千上万条帖子,我们没有采用 myisam 存储而用的是 innodb 存储;就算再好的设备也不可能很快的查询出来。
注:在 where 和 count(*)使用中 myisam 比 innodb 要快的多;因为 myisam 内置了一个计数器,count(*)可以直接从计数器当中读取,而 innodb 则要扫描全表。
所以在 innodb 上执行 count(*)时一般伴随 where,而且 where 中要包含主键以外的索引列。
如果必须要实施更新就专门为这个功能创建一个表,要想查询结果就专门查看这个表就好了;到时候每秒产生的上万条帖子也是一种麻烦,反过来说但是到底有多少人会关注这个实时更新,如果把实时更新去掉就很容易实现;在通过创建统计表,每隔一定的时间去刷新便可以。这就是不合理的商业要求。

2:系统架构以及实现的影响
1)二进制多媒体数据
主要包括图片、视屏、其他二进制文件,如果放到数据库中数据空间资源消耗非常严重,另外一个就是消耗主机的 cpu 资源,因为数据库本就不是处理这些的优势,
解决办法:可以将这些二进制多媒体数据放到一个专门的文本文件中,然后给数据库做一个连接指向这个文本文件,实现数据库调用多媒体文件,有不用消耗数据库的空间和 cpu 资源。
2)超大文本数据
如果大的文本数据放到数据库当中也会造成空间的占用浪费问题。
解决方法:可以使用非关系型数据库进行存储
3)查询语句对性能的影响
每个 sql 语句在优化前后的性能差异也是各不相同
在数据库管理软件中,最大性能瓶颈就是在于磁盘 io、也就是数据的存取操作上面,而对于同一份数据,当我们以不同的方式去查找某一点内容时候,所需的读取数据量可能会有天壤之别,搜消耗的资源也区别很大
首先进行编写一个脚本插入 20000 行的数据

MySQL 性能优化注意事项以及索引

MySQL 性能优化注意事项以及索引

比如执行 sql 语句时可以用 explain 来查看执行计划:
 
MySQL 性能优化注意事项以及索引

使用其他方式再次查询打开 profiling 功能,来查看 sql 的实际执行计划
打开功能

MySQL 性能优化注意事项以及索引

开始查询

MySQL 性能优化注意事项以及索引

MySQL 性能优化注意事项以及索引

查看 profile 对数据库的 cpu,block,以及 io 的使用情况:

MySQL 性能优化注意事项以及索引
 
4)数据库的 schema(模式)设计对性能也有影响
5)硬件选择对性能的影响
数据库主机是存储数据的地方,所以 io 性能必须要优先考虑,无论是什么数据库都必须考虑的因素,当然和 io 相关的板卡
另外 cpu 的处理能力也不能忽视,企业中必须使用多核,另外内存也必须要大至少要 64G
其实数据库的优化不单单从物理方面进行提高配置,也包括逻辑化如连接数。。。,和商业的需求。总之就是系统架构最优化、逻辑结构精简化、硬件设施理性化
 
 
二、索引的介绍以及创建和使用
 
什么是索引?
索引(index)是帮助 mysql 高效获取数据结构,帮助 dba 快速定位,简单来说就相当于字典中的目录
索引的类型在上章讲过有三种 {B-Tree、R-Tree、Full-Tree} 类型、最常用的是 B -Tree
这里主要介绍的是 B -Tree 的索引结构:

MySQL 性能优化注意事项以及索引

如图:这里只说重点、浅蓝色的我们成为磁盘块、可以看到每个磁盘块包含几个数据项,和指针(黄色)其实真正的数据在叶子节点上,就是最下面的一层,而其他的不存放数据,只存放指引数据方向的索引而已。
例如:要查找 29,首先把磁盘块 1,加载到内存,发生一次 io,在内存中用二分查找确定 29 在 17 和 35 之间,锁定磁盘块 1 的 p2 指针,由此往下推算,直到第三层算出为止。
 
索引的优点:
让 mysql 高效的运行,可以大大提高 mysql 的查询效率,数据约束,快速定位
使用索引的代价:
1)需要加载到内存,以文件的形式存放在硬盘中,所以增加磁盘的开销
2)写数据,需要更新索引,对数据库是很大的开销,降低表更新、添加和删除的速度
 
不建议使用索引的情况:
1)表记录较少
2)索引的选择性较低,指不重复的索引与表记录数的比值,取值范围(0-1),选择性越高,索引价值越大
 
1:普通索引
最基本的索引,没有任何限制
create index index_name on tablename(columm1【column2,。。。。。】)
2:唯一索引
和普通索引类似,不同的就是索引列的值必须唯一,但允许空值,指的就是 null,如果是组合索引,列的值必须唯一。
create table tablename(id int not null,username varchar(16) not null,primary key(id));
3:组合索引
为了进一步提升 mysql 的效率,可以使用组合索引
create index index_name on table_name(column1,column2,column3);
这样的组合索引效率高于单列的索引,而且采用的是最左前缀的结果。简单理解就是从最左边开始组合。
4:全文索引
只用于 myisam 表对文本域进行索引。字段包括 char、varchar、text
 
不过切记大容量的数据表,生成全文索引是一个非常消耗时间和硬盘的做法
 
查看索引
show  index  from  table_name
show  keys  from  table_name
创建索引的时机:
一般在 where 和 join 子句中需要建立索引
使用索引的注意事项:
某些情况下 like 才需要建立索引,因为在一通配符 % 和 - 开头查询时,mysql 不会使用索引
select * from table-name where name like‘%admin’;
另外还有就是不能再列上进行运算
select * from users where YEAR(adddate)<2000;
强每个行上进行运算,将导致索引失效而进行全表扫描
可修改为 select * from users where adddate<2000-10-4;
总结:
索引的优化过程中主要用于存在 where 和 join 子句当中
索引中的列的基数越大,索引的效果越好
使用的短索引,如果对字符串进行索引,应该指定一个前缀长度,可节省大量的索引空间,提升查询的速度

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-06/145079.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2531字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7798165
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装 Black 群晖 DSM7.2 系统安装教程(在 Vmware 虚拟机中、实体机均可)! 前言 大家好,...
手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板

手把手教你,购买云服务器并且安装宝塔面板 前言 大家好,我是星哥。星哥发现很多新手刚接触服务器时,都会被“选购...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛 NAS 硬件 03:五盘位 +N5105+ 双网口的成品 NAS 值得入手吗 前言 大家好,我...
星哥带你玩飞牛NAS-11:咪咕视频订阅部署全攻略

星哥带你玩飞牛NAS-11:咪咕视频订阅部署全攻略

星哥带你玩飞牛 NAS-11:咪咕视频订阅部署全攻略 前言 在家庭影音系统里,NAS 不仅是存储中心,更是内容...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...
开发者福利:免费 .frii.site 子域名,一分钟申请即用

开发者福利:免费 .frii.site 子域名,一分钟申请即用

  开发者福利:免费 .frii.site 子域名,一分钟申请即用 前言 在学习 Web 开发、部署...
星哥带你玩飞牛NAS-5:飞牛NAS中的Docker功能介绍

星哥带你玩飞牛NAS-5:飞牛NAS中的Docker功能介绍

星哥带你玩飞牛 NAS-5:飞牛 NAS 中的 Docker 功能介绍 大家好,我是星哥,今天给大家带来如何在...
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...
星哥带你玩飞牛NAS-14:解锁公网自由!Lucky功能工具安装使用保姆级教程

星哥带你玩飞牛NAS-14:解锁公网自由!Lucky功能工具安装使用保姆级教程

星哥带你玩飞牛 NAS-14:解锁公网自由!Lucky 功能工具安装使用保姆级教程 作为 NAS 玩家,咱们最...