MYSQL骚操作之第三十九话之索引、ACID、事务、引擎

6 篇文章 0 订阅

前言

MYSQL数据库是当今数据库中最为潮流的一种,其余的还有ORACLE,postgresql两种,所面向包括12306信息管理系统等等,sql语句可以更加方便DBA操作mysql,同时更加方便运维工程师查询数据库,在服务中,无论是LAMP,还是LNMP等等,都需要对数据库进行调用和查阅,此时,MYSQL的作用就显得十分重要。

一、什么是索引

1、索引是一个排序的列表,在这个列表中存储着索引的值和包含这个值的数据所在行的物理地址(类似于C语言的链表通过指针指向数据记录的内存地址)。
2、使用索引后可以不用扫描全表来定位某行的数据,而是先通过索引表找到该行数据对应的物理地址然后访问相应的数据,因此能加快数据库的查询速度。
3、索引就好比是一本书的目录,可以根据目录中的页码快速找到所需的内容。
4、索引是表中一列或者若干列值排序的方法。
5、建立索引的目的是加快对表中记录的查找或排序

二、索引的作用

1、设置了合适的索引之后,数据库利用各种快速定位技术,能够大大加快查询速度,这是创建索引的最主要的原因。
2、当表很大或查询涉及到多个表时,使用索引可以成千上万倍地提高查询速度。
3、可以降低数据库的IO成本,并且索引还可以降低数据库的排序成本。
4、通过创建唯一(键)性索引,可以保证数据表中每一行数据的唯一性。
5、可以加快表与表之间的连接。
6、在使用分组和排序时,可大大减少分组和排序的时间。

三、索引的副作用

1、索引需要占用额外的磁盘空间。对于 MyISAM 引擎而言,索引文件和数据文件是分离的,索引文件用于保存数据记录的地址。而 InnoDB 引擎的表数据文件本身就是索引文件。
2、在插入和修改数据时要花费更多的时间,因为索引也要随之变动。

四、创建索引的原则依据

索引虽可以提升数据库查询的速度,但并不是任何情况下都适合创建索引。因为索引本身会消耗系统资源,在有索引的情况下,数据库会先进行索引查询,然后定位到具体的数据行,如果索引使用不当,反而会增加数据库的负担。
1、表的主键、外键必须有索引。因为主键具有唯一性,外键关联的是子表的主键,查询时可以快速定位
2、记录数超过300行的表应该有索引。如果没有索引,需要把表遍历一遍,会严重影响数据库的性能。
3、经常与其他表进行连接的表,在连接字段上应该建立索引。
4、唯一性太差的字段不适合建立索引。
5、更新太频繁地字段不适合创建索引。
6、经常出现在 where 子句中的字段,特别是大表的字段,应该建立索引。
7、索引应该建在选择性高的字段上。
8、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引。

五、走进索引具体操作

1、普通索引

1.1、直接创建索引

在这里插入图片描述

1.2、修改表方式创建

在这里插入图片描述

1.3、创建表方式创建

在这里插入图片描述

2、唯一索引

与普通索引类似,但区别是唯一索引列的每个值都唯一。
唯一索引允许有空值(注意和主键不同)。如果是用组合索引创建,则列值的组合必须唯一。添加唯一键将自动创建唯一索引。

2.1、直接创建唯一索引

在这里插入图片描述

2.2、修改表方式创建

在这里插入图片描述

2.3、创建表的时候指定

在这里插入图片描述

3、主键索引

3.1、创建表的时候指定

在这里插入图片描述

4、组合索引

4.1、创建表时创建组合索引

在这里插入图片描述

4.2、组合索引的顺序

组合索引创建的字段顺序是其触发索引的查询顺序
在这里插入图片描述

5、全文索引

5.1、直接创建全文索引

在这里插入图片描述

6、查看索引

6.1、第一种

在这里插入图片描述

6.2、第二种

在这里插入图片描述

7、删除索引

7.1、直接删除索引

在这里插入图片描述

7.2、删除主键索引

在这里插入图片描述

六、MYSQL事务

1、MYSQL事务的概念

MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中, 要删除一个人员,即需要删除人员的基本资料,又需要删除和该人员相关的信息,如信箱, 文章等等。这样,这些数据库操作语句就构成一个事务!

1.1、事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这一组数据库命令要么都执行,要么都不执行。
1.2、事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时,事务是最小的控制单元。
1.3、事务适用于多用户同时操作的数据库系统的场景,如银行、保险公司及证券交易系统等等。
1.4、事务是通过事务的整体性以保证数据的一致性。

七、事务的ACID特点

ACID是指在可靠数据库管理系统中,事务应该具有四个特性:原子性、一致性、隔离性、持久性

1.原子性

指事务是一个不可再分割的工作单位,事务中的操作要么都发生,要么都不发生。事务是一个完整的操作,事务的各元素是不可分的。事务中的所有元素必须作为一个整体提交或回滚。如果事务中的任何元素失败,则整个事务将失败。

2.一致性

指在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。当事务完成时,数据必须处于一致状态。在事务开始前,数据库中存储的数据处于一致状态。在正在进行的事务中,数据可能处于不一致的状态。当事务成功完成时,数据必须再次回到已知的一致状态。

3、隔离性

指在并发环境中,当不同的事务同时操纵相同的数据时,每个事务都有各自的完整数据空间。对数据进行修改的所有并发事务是彼此隔离的,表明事务必须是独立的,它不应以任何方式依赖于或影响其他事务。修改数据的事务可在另一个使用相同数据的事务开始之前访问这些数据,或者在另一个使用相同数据的事务结束之后访问这些数据。一个事务的执行不能被其他事务干扰事务之间的相互影响分为几种,分别为:

①、脏读(读取未提交数据)

脏读指的是读到了其他事务未提交的数据,未提交意味着这些数据可能会回滚,也就是可能最终不会存到数据库中,也就是不存在的数据。读到了并一定最终存在的数据,这就是脏读

②、不可重复读(前后多次读取,数据内容不一致)

一个事务内两个相同的查询却返回了不同数据。这是由于查询时系统中其他事务修改的提交而引起的。

③、幻读(前后多次读取,数据总量不一致)

一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,另一个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,操作前一个事务的用户会发现表中还有没有修改的数据行,就好象发生了幻觉一样。

④、丢失更新

两个事务同时读取同一条记录,A先修改记录,B也修改记录(B不知道A修改过),B提交数据后B的修改结果覆盖了A的修改结果。

4、持久性

在事务完成以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。指不管系统是否发生故障,事务处理的结果都是永久的。一旦事务被提交,事务的效果会被永久地保留在数据库中

八、MYSQL及事务隔离级别(四种)

1、read uncommitted(未提交读)

读取尚未提交的数据 :不解决脏读,允许脏读,其他事务只要修改了数据,即使未提交,本事务也能看到修改后的数据值。也就是可能读取到其他会话中未提交事务修改的数居。

2、read committed(提交读)

读取已经提交的数据 :可以解决脏读,只能读取到已经提交的数据。Oracle等多数数据库默认都是该级别〈不重复读)。

3、repeatable read(可重复读)

重读读取可以解决脏读 和 不可重复读,可重复读。无论其他事务是否修改并提交了数据,在这个事务中看到的数据值始终不受其他事务影响

4、serializable(串行化)

可以解决 脏读 不可重复读 和 虚读—相当于锁表,完全串行化的读,每次读都需要获得表级共享锁,读写相互都会阻塞。

5、MYSQL默认的事务处理级别是repeatable read、
6、事务隔离级别的作用范围:全局级、会话级
6.1、查询全局事务隔离级别Show global variables like ‘%isolation%’
在这里插入图片描述
6.2、查询会话事务隔离级别
Show session variables like ‘%isolation%’
在这里插入图片描述
6.3、设置全局事务隔离级别
6.4、设置会话事务隔离级别
在这里插入图片描述

九、事务控制语句

1、创建新库,创建新表、插入新的信息
2、测试提交事务
在这里插入图片描述
在这里插入图片描述

3、测试回滚事务
在这里插入图片描述
在这里插入图片描述
4、测试多点回滚
在这里插入图片描述
在这里插入图片描述
5、使用set设置控制事务
Set autocommit=0;禁止自动提交
Set autocommit=1 开启自动提交
在这里插入图片描述

十、MYSQL存储引擎

1、存储引擎概念MySQL中的数据用各种不同的技术存储在文件中,每一种技术都使用不同的存储机制、索引技巧、锁定水平并最终提供不同的功能和能力,这些不同的技术以及配套的功能在MySQL中称为存储引擎存储引擎是MySQL将数据存储在文件系统中的存储方式或者存储格式
1.1、MYSQL常用的存储引擎MYISAM和INNODB;
1.2、MySQL数据库中的组件,负责执行实际的数据I/O操作
1.3、Mysql系统中,存储引擎处于文件系统之上,在数据保存到数据文件之前会传输到存储引擎,之后按照各个存储引擎的存储格式进行存储。

2、MYISAM
2.1、myisam不支持事务,也支持外键约束,只支持全文索引,数据文件和索引文件是分开保存的
2.2、访问速度快,对事务完整性没有要求
2.3、Myisam适合查询,插入为主的应用场景
2.4、MYISAM在磁盘上存储三个文件,文件名和表名相同,但是扩展名分别是:.fm文件存储表结构的定义,数据文件的扩展名未。Myd,索引文件的扩展名是.MYI
2.5、表级锁定形式,数据在更新时锁定整个表,数据库在读写过程中相互阻塞,串行操作,按照顺序操作,每次在读或写的时候会把全表锁起来。会在数据写入的过程中阻塞用户数据的读取,也会在数据读取的过程中阻塞用户的数据写入,特性;数据单独写入或读取,速度过程较快且占用资源相对少。MYISAM是表级锁定,读或写无法同时进行,好处是:分开执行时,速度快,资源占用相对较少。
2.6、MYISAM表支持3种不同的存储格式:1、静态固定长度表;2、动态表;3、压缩表2.7、MYISAM适用的生产场景:
2.7.1、公司业务不需要事务的支持
2.7.2、单方面读取或写入数据比较多的业务
2.7.3、MyISAM存储引擎数据读写都比较频繁场景不适合
2.7.4使用读写并发访问相对较低的业务
2.7.5、数据修改相对较少的业务
2.7.6、对数据业务一致性要求不是非常高的业务
2.7.7、服务器硬件资源相对比较差
2.8、适合于单方向的任务场景,同时并发量不高,对于事务要求不高的场景

总结

一、普通索引

1、直接创建索引
create index 索引名 on 表名 (列名);
2、创建表的时候指定索引
create table 表名 add index 索引名 (列名);
3、创建表的时候指定索引
create table 表名 (字段1 数据类型,字段2 数据类型,index 索引名 (列名));

二、唯一索引

1、直接创建唯一索引
create unique index 索引名 ON 表名(列名);
2、修改表方式创建
alter table 表名 add index unique 索引名 (列名);
3、创建表的时候指定
create table 表名(字段1 数据类型,字段2 数据类型,unique 索引名 (列名));

三、主键索引

1、创建表的时候指定
create table 表名(字段1 数据类型,字段2 数据类型,primary key(列名));
2、修改表方式创建
alter table 表名 add primary key(列名);;

四、组合索引

create table 表名 (列名1 数据类型,列名2 数据类型,列名3 数据类型,index 索引名 (列名1,列名2,列名3))

五、全文索引

1、直接创建索引
create fulltext index 索引名 ON 表名(列名);
2、修改表方式创建
alter table 表名 add fulltext 索引名(列名);
3、创建表的时候指定索引
create table 表名(字段1 数据类型,字段2 数据类型,fulltext 索引名(列名));
4、使用全文索引查询
select * from 表名 where match(列名) against(‘查询内容’);

六、查看索引

1、show index from 表名;
2、show index from 表名\G;
3、show keys from 表名;
4、show keys from 表名\G;

七、删除索引

1、直接删除索引
drop index 索引名 on 表名;
2、修改表方式删除索引
alter table 表名 drop index 索引名;
3、删除主键索引
alter table 表名 drop primary KEY;

八、事务的ACID特点

1、原子性
2、一致性
3、隔离性
3.1、脏读:读到别人暂未提交的数据
3.2、不可重复读:自己第一次读到的数据,第二次因为别人提交了数据导致我第二次看到的和第一次不一样。
3.3、幻读:事务A 按照一定条件进行数据读取, 期间事务B 插入了相同搜索条件的新数据,事务A再次按照原先条件进行读取时,发现了事务B 新插入的数据
3.4、丢失更新:两个事务同时读取同一条记录,A先修改记录,B也修改记录(B不知道A修改过),B提交数据后B的修改结果覆盖了A的修改结果4、持久性

九、MYSQL及事务隔离级别

1、read uncommitted;未提交读
2、read committed;提交读
3、repeatable read 可重复读
4、serialization 串行化

十、存储引擎

1、myisam
2、innoDB

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值