MySQL高级——索引和事务

前言

MySQL高级索引和事务
对于刚步入对mysql高级的学习,除了会编写SQL语句,会用程序连接数据库进行增删查改操作,还必须对数据库的事务的概念和是数据库索引有一定的理解

(一)、索引的简介

1、索引是什么?

类似于字典的音序表

2、为什么要有索引?

为了快速查询节省时间

3、索引的优劣

(1)、优点

可以快速检索,减少 I/O 次数,加快检索速度;根据索引分组和排序,可以加快分组和排序

(2)、缺点

占用储存空间

二、索引的规则

1、使用分类

(1)主键索引:即主索引,根据主键 pk_clolum(length)建立索引,不允许重复,不允许空值;
(2)唯一索引:用来建立索引的列的值必须是唯一的,允许空值;
(3)普通索引:用表中的普通列构建的索引,没有任何限制;
(4)全文索引:用大文本对象的列构建的索引;
(5)组合索引:用多个列组合构建的索引,这多个列中的值不允许有空值。

2、使用场景

(1)适合建立索引的情况
1、主键自动建立唯一索引;
2、经常作为查询条件在 WHERE 或者 ORDER BY 语句中出现的列要建立索引;
3、作为排序的列要建立索引;
4、查询中与其他表关联的字段,外键关系建立索引;
5、高并发条件下倾向组合索引;
6、用于聚合函数的列可以建立索引,例如使用了 max(column_1)或者 count(column_1)时的 column_1 就需
要建立索引。
(2)不适合建立索引的情况
1、经常增删改的列不要建立索引
2、有大量重复的列不建立索引
3、表记录太少不要建立索引
4、索引失效的情况

三、索引的使用

1.创建索引

create table mytable(
id int not null,
username varchar(16),
index myindex(username(16))
);
-- index是索引
-- myindex是索引名字(自己起的)

创建索引方式2
create index myindex on mytable(username(16))

2.查看索引

show index from mytable

2.删除索引

drop index myindex on mytable

(一)、事务

1.什么是事务

一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,该业务就是一个最小的工作单元)

2.事务的语法

开启事务
	start transaction;-- 手动开启事务
提交事务
	commit;-- 提交事务,commit 之后即改变底层数据库数据
回滚事务
	rollback;-- 回滚操作

3.事务的四大特征

(1)原子性:事务是最小单位,不可再分;
(2)一致性:事务要求所有的 DML 语句操作的时候,必须保证同时成功或者同时失败;
(3)隔离性:同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰;
(4)持久性:是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。

二、事务的四个隔离级别

1.读未提交(read uncommitted):

事务 A 和事务 B,事务 A 未提交的数据,事务 B 可以读取到,这里读取到的数据叫做“脏数据”。这种隔离级别最低,一般是在理论上存在,数据库隔离级别一般都高于该级别;

2.读已提交(read committed):

事务 A 和事务 B,事务 A 提交的数据,事务 B 才能读取到。这种隔离级别高于读未提交,可以避免“脏数据”。但如果事务 A 多次读取同一数据,而事务 B 在事务 A 多次读取的过程中,对数据作了更新并提交,导致事务 A 多次读取同一数据时,结果不一致,这种现象称为“不可重复读”;

3.可重复读(repeatable read):

事务 A 和事务 B,事务 A 提交之后的数据,事务 B 读不到事务 A 提交的数据。这种隔离级别高于读已提交,但如果事务 A在修改数据的过程中(比如将所有记录状态设为 1),如果事务 B 向同一张表中插入一条新记录(状态为 0),事务 A提交后再次查询表,会发现有一条记录状态没有改成 1,好像发生了幻觉,这种现象称为“幻读”。可重复读是 MySQL 默认隔离级别;

4.串行化(serializable):

事务 A 和事务 B,事务 A 在操作数据库时,事务 B 只能排队等待。这种级别可以避免“幻读”,每一次读取的都是数据库中真实存在数据,事务 A 与事务 B 串行,而不并发。

总结

本篇文章希望会对读者提供帮助谢谢支持。。。。。

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 11
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值