Redis 中的事务

使用MULTI与EXEC之间之间执行多个操作来处理一个事务:

127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SADD key element
QUEUED
127.0.0.1:6379> LPUSH helper_key x
QUEUED
127.0.0.1:6379> EXEC
1) (integer) 1
2) (integer) 1

MULTI开启事务(开启成功返回OK),MULTI与EXEC之间的多个操作仅仅是暂时缓存起来(我们可以看到返回为QUEUED),直到执行EXEC时,提交事务。

Redis 超时(TTL):数据在限定时间内存活

Redis可以expire对键设置生命周期TTL:

/*先存入数据到list中*/
127.0.0.1:6379> lpush ttlTestList ttl
(integer) 1
/*再设置超时时间(为5秒失效)*/
127.0.0.1:6379> expire ttlTestList 5
(integer) 1

5秒后获取元素为空:

127.0.0.1:6379> lpop ttlTestList
(nil)

我们看到超时时间一过,ttlTestList键被删除了

127.0.0.1:6379> keys *
1) "zset"
2) "set"
3) "helper_key"
4) "mylist"
5) "user"
6) "mykey"
7) "relList"

上面的例子使用了EXPIRE来设置超时时间(也可以再次调用这个命令来改变超时时间,使用PERSIST命令去除超时时间 )。
使用ttl:

127.0.0.1:6379> lpush ttlTestList ttl
(integer) 1
/*设置超时时间为10秒*/
127.0.0.1:6379> expire ttlTestList 10
(integer) 1
/*使用ttl查看剩余存活时间*/
127.0.0.1:6379> ttl ttlTestList
(integer) 5

KEYS 命令

keys pattern 可以查看所在数据库中符合pattern匹配模式的键,pattern通配符:

符号

含义

?

匹配一个字符

*

匹配任意字符(包括0个字符)

[]

匹配括号里的任意字符,也可以使用“-”表示范围,如a[b-d]可以匹配ab、ac、ad

\x

可以匹配转义字符。如匹配?,就使用\?

127.0.0.1:6379[1]> keys list?
1) "list1"

注意: keys会便利数据库的所有键,如果键数量较大,不建议在生产使用.

EXISTS 命令

exists 用于判断某个键是否存在,存在返回1,否则返回0.

127.0.0.1:6379[15]> keys *
1) "testKey"
127.0.0.1:6379[15]> exists testKey
(integer) 1
127.0.0.1:6379[15]> exists testKey2
(integer) 0

DEL 命令

del 用于删除一个或多个键,del key [key2…],返回值是删除的键的个数:

127.0.0.1:6379[15]> del testKey
(integer) 1
/*因为之前已经删除testKey键了,再使用del操作时,实际上并没有删除任何键,于是返回0*/
127.0.0.1:6379[15]> del testKey
(integer) 0

SELECT 命令

Redis 的数据库默认存在编号为0-15的共计16个数据库实例,可以通过设置databases参数修改这个默认设置。我们可以使用SELECT命令选择使用指定的数据库:

/*选择使用数据库1*/
127.0.0.1:6379[1]> select 1
OK
/*在数据库1中设置一个键*/
127.0.0.1:6379[1]> lpush list1 ele1
(integer) 1
127.0.0.1:6379[1]> keys *
1) "list1"

切换数据库0,在数据库0中是看不到数据库1中的键的:

/*切换到数据库0*/
127.0.0.1:6379[1]> select 0
OK
/*数据库0中无键*/
127.0.0.1:6379> keys *
(empty list or set)

FLUSHALL 命令

flushall 命令会清除所有数据库实例的键值数据(默认配置的话数据库0-15会全删除)。恨他,就用flushall来对付他吧。

TYPE 命令

type 命令用来获取键的类型,返回值可能是 string(字符串类型)list(列表类型)set(集合类型)hash(散列类型)zset(有序集合类型)

RANDOMKEY

randomkey 可以随机获取当前数据库中的一个键。

127.0.0.1:6379> select 0
OK
127.0.0.1:6379> keys *
1) "strkey4"
2) "setKey"
3) "code_list1"
4) "foo"
5) "strkey3"
6) "strkey27"
7) "strkey6"
8) "strkey5"
127.0.0.1:6379> randomkey
"strkey4"
127.0.0.1:6379> randomkey
"setKey"
127.0.0.1:6379> randomkey
"strkey3"
127.0.0.1:6379> randomkey
"strkey4"
127.0.0.1:6379> randomkey
"strkey6"

RENAME 重命名键名

rename oldKeyName newKeyName 将oldKeyName 键改名为newKeyName。

127.0.0.1:6379> keys *
1) "strkey4"
2) "setKey"
3) "code_list1"
4) "foo"
5) "strkey3"
6) "strkey27"
7) "strkey6"
8) "strkey5"
127.0.0.1:6379> rename setKey setKey88
OK
127.0.0.1:6379> keys *
1) "strkey3"
2) "foo"
3) "code_list1"
4) "strkey5"
5) "strkey6"
6) "strkey4"
7) "setKey88"
8) "strkey27"

MOVE

move 命令可以将一个数据库中的键移动到另一个数据库中:

/*数据库0中的key*/
127.0.0.1:6379> keys *
 1) "counter:__rand_int__"
 2) "key:__rand_int__"
 3) "strkey3"
 4) "code_list1"
 5) "strkey5"
 6) "strkey6"
 7) "strkey4"
 8) "setKey88"
 9) "mylist"
10) "strkey27"
/*数据库1中无key*/
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> keys *
(empty list or set)
/*移动0中的key到1中*/
11) "strkey27"
127.0.0.1:6379> move foo 1
(integer) 1
127.0.0.1:6379> keys *
 1) "counter:__rand_int__"
 2) "key:__rand_int__"
 3) "strkey3"
 4) "code_list1"
 5) "strkey5"
 6) "strkey6"
 7) "strkey4"
 8) "setKey88"
 9) "mylist"
10) "strkey27"
/*查看1中,可以看到刚刚移动过来的key:foo*/
127.0.0.1:6379[1]> keys *
1) "foo"