命令示例
1. KEYS/RENAME/DEL/EXISTS/MOVE/RENAMENX:(获取匹配的key/重新命名/删除key/判断是否存在/移动指定key/新值不存在才重新命名)
127.0.0.1:6379> flushdb //清空当前选择的数据库,以便于对后面示例的理解
OK
127.0.0.1:6379> set mykey 2 //准备数据
OK
127.0.0.1:6379> set mykey2 hello
OK
127.0.0.1:6379> sadd mysetkey 1 2 3
(integer) 3
127.0.0.1:6379> hset mmtest username kong
(integer) 1
//根据参数中的模式,获取当前数据库中符合该模式的所有key,从输出可以看出,该命令在执行时并不区分与Key关联的Value类型,模糊匹配
127.0.0.1:6379> keys my*
1) "mykey2"
2) "mykey"
3) "mysetkey"
127.0.0.1:6379> del mykey mykey2
(integer) 2
127.0.0.1:6379> exists mykey //查看删除的还存在不
(integer) 0
127.0.0.1:6379> exists mysetkey
(integer) 1
127.0.0.1:6379> move mysetkey 1 //将当前数据库中的mysetkey键移入到ID为1的数据库中,从结果可以看出已经移动成功
(integer) 1
127.0.0.1:6379> select 1 // 打开ID为1的数据库
OK
127.0.0.1:6379[1]> exists mysetkey //判断ID为1的数据库中是否有mysetkey
(integer) 1
127.0.0.1:6379[1]> select 0 //打开ID为0的数据库,默认数据库
OK
127.0.0.1:6379> exists mysetkey //判断mysetkey 还在ID为0的数据库中吗,返回0,不在
(integer) 0
127.0.0.1:6379> set mykey hello
OK
127.0.0.1:6379> rename mykey mykey1 //将mykey改名为mykey1
OK
127.0.0.1:6379> get mykey //由于mykey已经被重新命名,再次获取将返回nil。
(nil)
127.0.0.1:6379> get mykey1 //通过新的键名获取
"hello"
127.0.0.1:6379> rename mykey mykey1 //由于mykey已经不存在了,所以返回错误信息,
(error) ERR no such key
127.0.0.1:6379> set oldkey hello //为renamenx准备测试key
OK
127.0.0.1:6379> set newkey world
OK
127.0.0.1:6379> renamenx oldkey newkey //由于newkey已经存在,因此该命令未能成功执行
(integer) 0
127.0.0.1:6379> get newkey //查看newkey的值,发现它也没有被renamenx覆盖
"world"
在这有一点需要提醒的,上面也接触了,就是根据ID分数据库,默认的是ID为0的数据库,通过select进入指定的数据库,很像分区,在同一个数据库中,不管创建list,String,set等不允许key重复,但是可以在ID为0的创建一个key,在ID为1的创建另一个相同的key,不冲突,
127.0.0.1:6379> exists mysetkey //判断在ID为0的数据库中有没有key为mysetkey
(integer) 0
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> exists mysetkey //mysetkey在ID为1的数据库里有
(integer) 1
127.0.0.1:6379[1]> select 0 //回默认数据库
OK
127.0.0.1:6379> sadd mysetkey 1 2 3 //添加同样key,类型相同,内容也相同,添加成功
(integer) 3
127.0.0.1:6379> exists mysetkey //添加成功了,在此数据库存在了
(integer) 1
127.0.0.1:6379> select 1 //再回ID为1的数据库
OK
127.0.0.1:6379[1]> exists mysetkey //说明两个都存在,只是分别在不同的ID的数据库中
(integer) 1
2. PERSIST/EXPIRE/EXPIREAT/TTL: (将过期时间移除/设置声明周期/根据时间戳设置声明周期/获取剩余生命周期)
127.0.0.1:6379> del myset //删除数据
(integer) 0
127.0.0.1:6379> set mykey helo //准备测试数据
OK
127.0.0.1:6379> expire mykey 100 //设置过期时间100s,也就是保存时间
(integer) 1
127.0.0.1:6379> ttl mykey //查看还剩多长时间
(integer) 93
127.0.0.1:6379> persist mykey //立刻执行persist命令,该存在超时的键变成持久化的键,即将该Key的超时去掉
(integer) 1
127.0.0.1:6379> ttl mykey //ttl的返回值告诉我们,该键已经没有超时了
(integer) -1
127.0.0.1:6379> del mykey //为后面的expire命令准备数据
(integer) 1
127.0.0.1:6379> set mykey hello
OK
127.0.0.1:6379> expire mykey 100 //设置该键的过期时间100s
(integer) 1
127.0.0.1:6379> ttl mykey //查看还剩多长时间
(integer) 91
127.0.0.1:6379> expire mykey 20 //重新更新该键的超时时间为20s,
(integer) 1
127.0.0.1:6379> ttl mykey //确认一下,确实被重新更新了
(integer) 11
127.0.0.1:6379> set mykey world //立即更新该键的值,以使其超时无效
OK
127.0.0.1:6379> ttl mykey //从ttl的结果可以看出,在上一条修改该键的命令执行后,该键的超时也无效了
(integer) -1
3. TYPE/RANDOMKEY/SORT:(获取数据类型/随机获取一个key/排序)
127.0.0.1:6379> type mm //mm的类型,因为mm不存在此key,返回none
none
127.0.0.1:6379> type mykey //存在返回类型
string
127.0.0.1:6379> type mysetkey
set
127.0.0.1:6379> randomkey //随机返回一个key
"mysetkey"
127.0.0.1:6379> flushdb //清空数据库
OK
127.0.0.1:6379> randomkey //再随机获得,因为清空了,所以不存在了,返回nil
(nil)
对于清空数据库flushdb这个命令清空的是当前数据库,也就是上面在ID为0的数据库清空,那ID为1的数据库里的数据还是存在的, 所以这里要注意一下