mysql 索引、事务

一、索引
(1)什么是索引?
1:举例来讲就是:索引相当于字典的音序表,如果要查某个字,如果不使用音序表,则需要从几百页中逐页去查。
(2) 索引的优劣势
(1)索引的 优势:可以快速检索,减少 I/O 次数,加快检索速度;根据索引分组和排序,可以加快分组和排序。
(2)索引的 劣势:索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间是数据表的 1.5 倍;索引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除,
添加,修改)的效率,因为在修改数据表的同时还需要修改索引表。
(3)如何创建、查看、删除索引
(1)创建索引

CREATE TABLE mytable(
 id INT NOT NULL,
 username VARCHAR(16)NOT NULL,
 INDEX myindex (username(16))-- index 表示索引,myindex 表示定义的索引名称。
);

(2)查看索引

-- -- 查看表中的索引SHOW是查看命令  mytable 是表名;
SHOW INDEX FROM mytable;

(3)删除索引 两种方法

--  删除索引 语法 DROP INDEX 索引的名字 on 表名;
DROP INDEX myindex ON mytable;
--  ALTER TABLE 表名 DROP INDEX 索引的名字 ;
ALTER TABLE mytable DROP INDEX myindex;
-- 语法分析:代码中的 myindex 是创建索引时定义的索引名称。

(4)通过 explain 命令查看索引使用情况,代码如下所示:

explain select * from mytable where username = 'jack'

二 事务
(1) 什么是事务?
事务(Transaction):一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,该业务就是一个最小的工作单元)。
(2)在 mysql 中,事务的常规操作包括:开启事务、提交事务与回滚事务。
1) 开启事务
开启事务的语法如下所示:

start transaction;
或者
begin transaction;

2) 提交事务
提交事务的语法如下所示:

commit;

3) 回滚事务
回滚事务的语法如下所示

rollback;

手动开启事务,向 t_act 表中插入一行记录,提交事务。代码如下所示:

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

在这里插入图片描述

手动开启事务,向 t_act 表中插入一行记录,回滚事务。代码如下所示:

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

在这里插入图片描述

事务四大特征(ACID):
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 串行,而不并发。

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值