课程名称 :Redis 入门
课程章节 :Redis 事务
讲师:慕神
课程内容:
redis 特性
多数据库:从0开始 最多有16个数据库 默认链接的是0号数据库
选择数据库连接 select 1
移动key到数据库1 move key 1
开启事务 multi
提交事务 exec
回滚事务 discard
Redis一个实例包含多个数据库:默认16个
客户端默认连接0号数据库
select 1 #选择1号数据库
move name 1 #移动 name 到1号数据库
事务:
事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。
事务具有四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)。这个四个特性也简称为ACID特性。
原子性:事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。
一致性:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。
隔离性:一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其执行结果有任何影响。
为什么事务非正常结束时会影响数据库数据的正确性,请列举一例说明之。
答:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。
例如某工厂的库存管理系统中,要把数量为Q的某种零件从仓库1移到仓库2存放。
则可以定义一个事务T,T包括两个操作;Q1=Q1-Q,Q2=Q2+Q。如果T非正常终止时只做了第一个操作,则数据库就处于不一致性状态,库存量无缘无故少了Q。
multi:开启事务
exec:提交,执行的命令被原子化执行
discard:回滚
课程收获:redis 的事务和数据库引擎的事务还是有区别的,通过学习事务可以很好的理解事务的四个特性,理解程序在运行时为了保证一致性所做的一些方法,对我们以后程序的开发很有用处。