介绍
redis 中的事务开启后,可以将所有命令序列化并且顺序执行,该操作是原子性的,保证了程序执行的一致性。
基本用法
通过命令 multi 开启事务,并输入要执行的命令,这些命令将会被加入事务队列中等待执行,最后通过 exec 命令执行。
set wang 200
set yuan 200
//开启事务
multi
decrby wang 100
incrby yuan 100
exec
- 如果事务中的命令出现语法错误,会终止事务的执行,所有命令都不会执行
- 如果事务中的命令没有语法错误,但是对于数据类型的操作错误,错误命令不会执行,但是其他正确的命令会继续执行
redis 为什么没有回滚
- 程序员不该犯类型错误的低级失误,程序员要为自己的代码负责
- 为了使 redis 更简洁,执行效率更高
redis 事务相对于传统关系型数据库的事务处理更加简洁,没有复杂的回滚机制,没有众多的隔离级别,上手学习确实很快
监视KEY
在事务的命令输入之前,其它客户端对 KEY 的操作会影响事务最终执行的结果,为了保证事务执行的结果符合预期,我们需要对当前要修改的 KEY 进行监视,通过 wacth 方法设置,如果监视的 KEY 发生了变化,取消整个事务的执行,wacth 可以同时对多个 KEY 进行监视,其中只要有一个 KEY 发生变化,事务都会取消。这种形式是乐观锁的一种实现方法。
- 乐观锁的说明:乐观的看待这个世界,认为每次对数据的处理不会存在并发情况,只在数据更新时检查一次数据是否被修改。
watch wang
multi
>>>>>>>>>
//另一个客户端优先执行命令
set wang 0
<<<<<<<<<
set wang 99
exec
取消事务
decrby wang 100
incrby yuan 100
discard
取消监视
- 通过输入命令 unwatch,不需要输入任何参数
- 事务执行或取消时,自动取消监视
网友评论