MySQL高级第一章


学习内容:索引和事务

1、 索引的使用和语法
索引的语法:
索引的创建

SHOW INDEX FROM 表名;

索引的删除

drop index 索引名 on 表名;
alter table 表名 drop index 索引名;

查看索引

SHOW INDEX FROM 表名;

**2、事务的使用和语法** 语法:

开启事务

start transaction;

提交事务

commit;

回滚事务

rollback;

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

**事务的隔离级别**
  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 串行,而不并发


![在这里插入图片描述](https://img-blog.csdnimg.cn/20210309112958371.png)

学习时间:

2021/3/9
上午


**3.课堂案例** 索引案例 ``` create table mytables( id int not null, username varchar(16), index myindexs(username(16)) ); -- index是索引 -- myindexs是索引的名字(自己起的)

– 查看索引
show index from mytables;

– 删除索引
drop index myindexs on mytables

– 创建索引的方式2
create index myindexs on mytables(username(16));

事务案例

– 事务
create table t_act(
actno int primary key,
balance int
);
select * from t_act;

– 手动开启事务,向 t_act 表中插入一行记录,提交事务

start transaction;-- 手动开启事务
insert into t_act values(3,300); – 更新操作
commit;-- 提交事务,commit 之后即改变底层数据库数据
select * from t_act;

start transaction;-- 手动开启事务
insert into t_act values(4,300); – 更新操作
rollback;-- 回滚操作
select * from t_act;


## 总结:
		在这节中我学习了mysql高级,我学会了使用索引,学会了使用事务,索引可以让我在使用数据库的时候更加的便捷。
		同时事务可以让我在对数据进行修改的同时保证数据不会出错,但是事务的隔离级别还是有些困难的。
		前两个读未提交和读已提交还比较好理解,但是后面两个可重复的还有可串行化就比较难理解。
		同时在课堂上我也进行了索引和事务的联系,看了老师对事务的隔离级别进行的演示



**本次课重点难点:**
	本次课的重点难点就是在于事务的隔离级别,除此之外本次课上我们用到的单词也是比价重要的。
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值