天天看点

Redis基本操作进阶篇--事务学习

Redis中的事务(transaction)是一组命令的集合。一个事务中的命令要么全部执行,要么都不执行。Redis的事务没有关系数据库事务提供的回滚(rollback)功能。

Redis通过<code>MULTI</code>标记一个事务块的开始。事务块内的多条命令会按照先后顺序被放进一个队列(queued)当中,最后由<code>EXEC</code>命令原子性(atomic)地执行。

Redis保证一个事务中的所有命令要么都执行,要么都不执行。如果<code>EXEC</code>命令之前出现错误,则Redis会清空事务队列,事务中的所有命令都不执行。

此外,Redis的事务还能保证一个事务内的命令依次执行而不被其他命令插入。

Redis2.6.5之前的版本会忽略有语法错误的命令,然后执行事务中其它语法正确的命令。就之后版本而言,只要有一个命令有语法错误,执行<code>EXEC</code>命令后,Redis就会直接返回错误,不执行任何命令。

示例如下:

运行错误指的是在命令执行中出现的错误,如果Redis中出现了运行错误,事务中其它正确的命令会继续执行。

<code>WATCH</code>命令用于监视一个或多个键 ,如果在事务执行之前监视的键被其他命令修改,那么事务将被打断。