事务
概述
Redis中的事务(transaction)是一组命令的集合。一个事务中的命令要么全部执行,要么都不执行。Redis的事务没有关系数据库事务提供的回滚(rollback)功能。
Redis通过MULTI
标记一个事务块的开始。事务块内的多条命令会按照先后顺序被放进一个队列(queued)当中,最后由EXEC
命令原子性(atomic)地执行。
Redis保证一个事务中的所有命令要么都执行,要么都不执行。如果EXEC
命令之前出现错误,则Redis会清空事务队列,事务中的所有命令都不执行。
此外,Redis的事务还能保证一个事务内的命令依次执行而不被其他命令插入。
事务基础语法
multi # 开启事务
set name kang # 使命令进入等待执行的事务队列中
set age 18 # 使命令进入等待执行的事务队列中
exec # 按顺序执行事务块内所有的命令
错误处理
语法错误
Redis2.6.5之前的版本会忽略有语法错误的命令,然后执行事务中其它语法正确的命令。就之后版本而言,只要有一个命令有语法错误,执行EXEC
命令后,Redis就会直接返回错误,不执行任何命令。
示例如下:
multi
set key name kang
key * # 语法错误,返回值:(error) ERR unknown command `key`, with args beginning with: `*`,
exec # 返回值:(error) EXECABORT Transaction discarded because of previous errors.
运行错误
运行错误指的是在命令执行中出现的错误,如果Redis中出现了运行错误,事务中其它正确的命令会继续执行。
示例如下:
multi
set name kang
sadd name kang
set age 18
exec
# 返回值:
# 1) OK
# 2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
# 3) OK
WATCH命令
WATCH
命令用于监视一个或多个键 ,如果在事务执行之前监视的键被其他命令修改,那么事务将被打断。
set name kang
watch name
set name Kang
multi
set name kang
exec
# 返回值:(nil)
get name # 返回值:"Kang"