Redis -----5 事务

MULTI、EXEC、DISCARD和WATCH命令是基础能力

1 MULTI

开始事物,将命令放入队列

这个命令的运行格式如下所示:

MULTI

这个命令的返回值是一个简单的字符串,总是OK

2 EXEC

提交事物。
清除所有先前在一个事务中放入队列的命令,然后恢复正常的连接状态。

如果使用了WATCH命令,那么DISCARD命令就会将当前连接监控的所有键取消监控。

DISCARD
这个命令的返回值是一个简单的字符串,总是OK

3 DISCARD

清除队列的命令,并不是回滚

4 WATCH

当某个事务需要按条件执行时,就要使用这个命令将给定的键设置为受监控的。

这个命令的运行格式如下所示:

WATCH key [key …]
这个命令的返回值是一个简单的字符串,总是OK。

对于每个键来说,时间复杂度总是O(1)
watch 命令可以监控一个或多个键,一旦有其中一个键被修改(被删除),后面的事务就不会执行了。监控一直持续到 EXEC 命令

5 UNWATCH

6 事务回滚

1 执行事务命令的时候,在命令入队的时候,Redis 就会检测事务的命令是否正确,如果不正确则会产生错误。无论之前和之后的命令都会被事务所回滚,就变为什么都没有执行。

2 当命令格式正确,而因为操作数据结构引起的错误,则该命令执行出现错误,而其之前和之后的命令都会被正常执行。数据库很不一致。

1 只有当被调用的Redis命令有语法错误时,这条命令才会执行失败(在将这个命令放入事务队列期间,Redis能够发现此类问题),或者对某个键执行不符合其数据类型的操作:实际上,这就意味着只有程序错误才会导致Redis命令执行失败,这种错误很有可能在程序开发期间发现,一般很少在生产环境发现。
2 Redis已经在系统内部进行功能简化,这样可以确保更快的运行速度,因为Redis不需要事务回滚的能力。

上一篇:常用数据库字符串转换为时间戳


下一篇:寒假06,读后感第二篇