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

Posted kangyz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis基本操作进阶篇--事务学习相关的知识,希望对你有一定的参考价值。

事务

概述

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"

以上是关于Redis基本操作进阶篇--事务学习的主要内容,如果未能解决你的问题,请参考以下文章

06 python操作MySQL和redis(进阶)

高级Java程序员必问,Redis事务终极篇

Redis篇5-redis事务

Redis 学习 —— 数据类型及操作

Redis高级进阶

Java开发工程师进阶篇-深入浅出Redis