索引、事务和锁的简单介绍

一、索引的简单介绍:

什么是索引?为什么要有索引
索引在 MySQL 中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构。索引对于良好的性能非常关 键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要。

**

索引的优劣势:

**
索引的优势:可以快速检索,减少 I/O 次数,加快检索速度;根据索引分组和排序,可以加快分组和排序。
索引的劣势:索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间是数据表的 1.5 倍;索 引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除, 添加,修改)的效率,因为在修改数据表的同时还需要修改索引表。

navicat数据库对索引的一些使用:

– 创建表格时添加索引
CREATE TABLE mytable(
id int not null,
username VARCHAR(16) not null,
index myindex (username(16))
);

– 后添加索引
cretae index myindex no mytable(username(16));
– 或者
ALTER table mytable add index myindex(username);

– 查看索引
show index from mytable

– 删除索引
drop index myindex on mytabke;
– 或者
alter table mmytable drop index myindex;

– 通过explain命令查看索引使用情况;
explain select *from mytable where username = ‘jack’

二 、事务

什么是事务

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

事务的使用

  1. 开启事务 开启事务的语法如下所示:
    start transaction;
    或者begin transaction;

  2. 提交事务 提交事务的语法如下所示:
    commit;

  3. 回滚事务回滚事务的语法如下所示:
    rollback;

事务的特征 事务四大特征(ACID)


 原子性(A):事务是最小单位,不可再分;
 一致性©:事务要求所有的 DML 语句操作的时候,必须保证同时成功或者同时失败;
 隔离性(I):同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰;
 持久性(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、乐观锁

2、悲观锁

  1. 共享锁与排它锁
    共享锁(S):也称为读锁,允许事务读取一行数据。例如事务 T 对数据对象 A 加上 S 锁,则事务 T 可以读 A 但不能修改 A,其他事务只能再对 A 加 S 锁,而不能加 X 锁,直到 T 释放 A 上的 S 锁。这保证了其他事务可以读 A,但在 T 释放 A 上的 S 锁之前不能对 A 做任何修改。
    排它锁(X):也称写锁,允许事务删除或更新一行数据。例如事务 T 对数据对象 A 加上 X 锁,事务 T 可以读 A 也可以修改 A,其他事务不能再对 A 加任何锁,直到 T 释放 A 上的锁。
  2. 锁的粒度 锁的粒度就是你要锁定的范围是多大。使用锁时,锁定的东西越少,对其他竞争者影响越小,这个东西的大 小就是锁粒度。 例如卫生间里的洗漱台,马桶,浴缸,如果分别隔开(三个区域可以分别锁定,粒度小),就可以同时给三 个人使用。你关上浴室的门,别人还是可以洗手的;但如果卫生间的区域不隔开,一个人进卫生间锁上门,其他 人就进不去了。可见,锁的粒度越小,锁定的资源越少,对其他用户的影响就越小,当然,对系统的开销也越大。 锁的粒度分类:
     表级锁:开销小,加锁快,不会出现死锁。锁定粒度最大,适合查询为主的,只有少量按索引条件更新 数据的操作。缺点是资源争用概率高;
     行级锁:开销大,加锁慢,会出现死锁。锁定粒度最小,适合大量按索引条件并发更新少量不同数据, 同时又有并发查询的操作。使用行级锁定的主要是 InnoDB 存储引擎;
     页面锁:开销介于表锁与行锁之间,会出现死锁
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值