redis中key的各种通用操作(六)

命令示例

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的数据库里的数据还是存在的, 所以这里要注意一下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值