事务
ACID 要么同时成功 要么同时失败
事务等于一组命令的集合
相当于一组命令的队列 事务中的所有命令都会被序列化
会按照顺序 一次性 顺序执行 ,执行过程中不会被打断。
Redis的事务没有隔离级别的概念 所以不会出现传统数据库隔离级别(脏读、幻读、不可重复读)等情况
Redisa单条命令保证原子性 Redis事务不保证原子性。
所有的redis命令在事务中 并没有被直接执行,只有真正执行到这条命令的时候才执行
redis 事务:
- 开启事务(multi)
- 命令入队(具体命令)
- 执行事务(exec)
开启一个事务
127.0.0.1:6379> MULTI #开启事务
OK
127.0.0.1:6379> set key1 v1
QUEUED #进入队列
127.0.0.1:6379> set key2 v2
QUEUED
127.0.0.1:6379> get key1
QUEUED
127.0.0.1:6379> set key3 v3
QUEUED
127.0.0.1:6379> exec #执行事务
1) OK #key1 v1 创建成功
2) OK #key2 v2 创建成功
3) "v1" #get key1
4) OK #key3 v3创建成功
取消一个事务
执行完了 这个事务就没有了 如果需要 需要再次开启
127.0.0.1:6379> MULTI #上面执行完成事务就没有了 需要再次开启事务
OK
127.0.0.1:6379> set key1 v1
QUEUED #进入队列
127.0.0.1:6379> set key2 v