2021-03-10

MySQL高级

  1. 索引:创键索引: 语法 CREATE INDEX 索引名 ON mytable(字段名(16)); 查询索引: 语法 SHOW INDEX FROM 表名 删除索引: 语法 DROP INDEX 索引名 ON 表名; 查看索引使用情况: 语法 explain select * from 表名 where 字段名 = ‘jack’
    索引的使用规则:
    索引分类: 主键索引、唯一索引、普通索引、全文索引、组合索引 1、 主键索引:即主索引,根据主键 pk_clolum(length)建立索引,不允许重复,不允许空值; 2、唯一索引:用来建立索引的列的值必须是唯一的,允许空值; 3、普通索引:用表中的普通列构建的索引,没有任何限制; 适合建立索引的情况: 1、主键自动建立唯一索引; 2、经常作为查询条件在WHERE 或者 ORDER BY 语句中出现的列要建立索引; 3、作为排序的列要建立索引; 4、查询中与其他表关联的字段,外键关系建立索引; 5、高并发条件下倾向组合索引; 6、用于聚合函数的列可以建立索引,例如使用了 max(column_1)或者 count(column_1)时的 column_1就需要建立索引。 不适合建立索引的情况: 1、经常增删改的列不要建立索引; 2、有大量重复的列不建立索引; 3、表记录太少不要建立索引。 索引失效的情况;
    2:事务简介: 什么是事务:保证数据的一致性

事务的语法:
在 mysql 中,事务的常规操作包括:开启事务、提交事务与回滚事务

开启事务
语法:start transaction; 或者begin transaction;
提交事务
语法:commit;
回滚事务
语法:rollback;
案例一:
手动开启事务,向 t_act 表中插入一行记录,提交事务。
start transaction;-- 手动开启事务
insert into t_act values(3,300); – 更新操作
commit;-- 提交事务,commit 之后即改变底层数据库数据
select * from t_act;
在 MySQL 中,默认情况下,事务是自动提 交的,也就是说,只要执行一条 DML 语句就开启了事务,并且提交了事务

案例二:
手动开启事务,向 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):是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。

事务的隔离级别:
事务的隔离级别有 4 个:

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

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

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

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值