Redis基础系列-0x009:事务

0x001 概述

redis的事务不具有原子性,在事务中,多条命令执行时,若是其中一条或者多条命令执行失败,并不会影响其余命令的执行,以前执行成功的命令也不会回滚,而以后还没有执行的命令将会继续执行。redis

0x002 执行一个事务

命令格式:code

- `MULTI`:开始事务
    - `command`:命令入队
    - `EXEC`:执行
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET name j
QUEUED
127.0.0.1:6379> SET age 11
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) OK
127.0.0.1:6379> GET name
"j"
127.0.0.1:6379> get age
"11"

0x003 放弃执行事务

命令格式:事务

- `MULTI`:开始事务
    - `command`:命令入队
    - `DISCARD`:取消事务
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET num 100
QUEUED
127.0.0.1:6379> DISCARD
OK
127.0.0.1:6379> GET num
(nil)

0x004 非原子性

# 先放入一个String
127.0.0.1:6379> SET name lyxxxx
OK
# 此时重新设置`name`为`hash`将会报错,由于类型不匹配
127.0.0.1:6379> hset name first lin
(error) WRONGTYPE Operation against a key holding the wrong kind of value
# 此时开始事务
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set age 25
QUEUED
127.0.0.1:6379> set name first l
QUEUED
127.0.0.1:6379> set sex male
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) (error) ERR syntax error 
3) OK
# 从上面的(2)能够看出`set name first l`执行失败了,可是(3)仍是成功了
127.0.0.1:6379> get sex
"male"

0x005 监听key改变,取消事务

命令格式:get

- `WATCH key [key key ...]`:监听`key`
    - `UNWATCH`:取消监听
  • 监听namehash

    127.0.0.1:6379> watch name
    OK
  • name改变io

    127.0.0.1:6379> set name lyxxx2
    OK
  • 执行事务,由于name 已经被改变了事务执行失败了,返回nil,而且值未被改变command

    127.0.0.1:6379> MULTI
    OK
    127.0.0.1:6379> set name lxxxx3
    QUEUED
    # name 已经被改变了,因此事务执行失败了
    127.0.0.1:6379> EXEC
    (nil)
    127.0.0.1:6379> get name
    "lyxxx2"
  • 取消监听并再次执行事务,此时事务将会成功error

    127.0.0.1:6379> UNWATCH 
    OK
    127.0.0.1:6379> MULTI
    OK
    127.0.0.1:6379> set name lxxxx3
    QUEUED
    127.0.0.1:6379> EXEC
    1) OK
    127.0.0.1:6379> GET name
    "lxxxx2"
相关文章
相关标签/搜索