事务
1,定义
-
原子性:一个事物必须视为一个不可分割的最小工作单元,整个事物中所有操作要么全部提交成功,要么全部回滚失败,对于一个事物来说,不可能只执行其中一部分操作
-
一致性:数据库总是从一个一致性的状态转换到另一个一致性的状态
-
隔离性:一个事务所做的修改在最终提交以前,对其他事务不可见
-
持久性:一旦事务提交,则其所做的修改就会永久保持到数据库中
-
数据库事务是逻辑上的一组SQL语句,组成这组操作的各个语句,执行是要么成功,要么失败
-
在mysql中,insert update delete 会自动触发事务,那么为什么还需要手动编写事务,这是因为当我们想要多个sql语句同时成功,同时失败的时候,
-
单个的sql的事务完成不了这样的需求的时候就可以主动开启事务
2,事物开启
'''
begin;
or
start transaction;
在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。
因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。
'''
3,结束事务(提交or回滚)
'''
开启之后就可以写你的sql组合语句了,写完之后commit提交执行sql组合,或者使用rollback撤销sql执行也称之为回滚
'''
4 ,直接用 SET 来改变 MySQL 的自动提交模式:
'''
SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交
'''
5, 事务控制语句:
'''
BEGIN或START TRANSACTION;显式地开启一个事务;
COMMIT;也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改成为永久性的;
ROLLBACK;有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;
SAVEPOINT identifier;SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT;
RELEASE SAVEPOINT identifier;删除一个事务的保存点,当没有指定的保存点时,执行该语句会抛出一个异常;
ROLLBACK TO identifier;把事务回滚到标记点;
SET TRANSACTION;用来设置事务的隔离级别。InnoDB存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。
'''
索引机制
1,定义和一些概念
- 索引:是帮助MySQL高效获取数据的数据结构
- 索引一般以文件的形式存在于磁盘上,索引检索需要IO操作,所以评价一个数据结构作为索引的优劣最重要的指标就是在查找过程中磁盘IO操作次所的渐进复杂度
- 在MySQL中,索引属于储存引擎级别的概念,不同储存引擎对索引的实现方式是不同的
2,索引分类:
- 哈希索引
- B树索引
3,索引的优点
- 索引大大减少了服务器需要扫描的数据量
- 索引可以帮助服务器避免排序和临时表
- 索引可以将随机IO变为顺序IO
4,索引的缺点
- 插入,删除数据修改,维护,速度下降,占用物理和数据空间
5,索引类型
- 普通索引
- 唯一索引
- 主键索引
- 全文索引