Redis 键(key)

Redis 键命令用于管理 redis 的键。

DEL key

该命令用于在 key 存在时删除 key。

127.0.0.1:6379> set w3ckey redis
OK
127.0.0.1:6379> EXISTS w3ckey
(integer) 1
127.0.0.1:6379> del w3ckey
(integer) 1
127.0.0.1:6379> EXISTS w3ckey
(integer) 0
127.0.0.1:6379>

DUMP

DUMP key

序列化给定 key ,并返回被序列化的值。

返回值

如果 key 不存在,那么返回 nil 。 否则,返回序列化之后的值。

127.0.0.1:6379> SET greeting "hello, dumping world!"
OK
127.0.0.1:6379> dump greeting
"\x00\x15hello, dumping world!\a\x00,\x7f\xe7\xf1%\xed(W"
127.0.0.1:6379> DUMP not-exists-key
(nil)
127.0.0.1:6379>

EXISTS

EXISTS key

检查给定 key 是否存在。

返回值

若 key 存在返回 1 ,否则返回 0 。

redis 127.0.0.1:6379> set runoob-new-key newkey
OK
redis 127.0.0.1:6379> EXISTS runoob-new-key
(integer) 1
redis 127.0.0.1:6379>

EXPIRE

EXPIRE key seconds

为给定 key 设置过期时间,以秒计。

返回值

设置成功返回 1 。 当 key 不存在或者不能为 key 设置过期时间时(比如在低于 2.1.3 版本的 Redis 中你尝试更新 key 的过期时间)返回 0

redis 127.0.0.1:6379> SET runooobkey redis
OK
redis 127.0.0.1:6379> EXPIRE runooobkey 60
(integer) 1

以上实例中我们为键 runooobkey 设置了过期时间为 1 分钟,1分钟后该键会自动删除。

EXPIREAT

EXPIREAT key timestamp

EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。 不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳(unix timestamp)。

返回值

设置成功返回 1 。 当 key 不存在或者不能为 key 设置过期时间时(比如在低于 2.1.3 版本的 Redis 中你尝试更新 key 的过期时间)返回 0 。

redis 127.0.0.1:6379> SET runoobkey redis
OK
redis 127.0.0.1:6379> EXPIREAT runoobkey 1293840000
(integer) 1
redis 127.0.0.1:6379> EXISTS runoobkey
(integer) 0

PEXPIRE

PEXPIRE key milliseconds

设置 key 的过期时间以毫秒计。

redis> SET mykey "Hello"
"OK"
redis> PEXPIRE mykey 1500
(integer) 1
redis> TTL mykey
(integer) 1
redis> PTTL mykey
(integer) 1498
redis>

PEXPIREAT

PEXPIREAT key milliseconds-timestamp

设置 key 过期时间的时间戳(unix timestamp) 以毫秒计

返回值

设置成功返回 1 。 当 key 不存在或者不能为 key 设置过期时间时(比如在低于 2.1.3 版本的 Redis 中你尝试更新 key 的过期时间)返回 0 。

redis 127.0.0.1:6379> SET runoobkey redis
OK
redis 127.0.0.1:6379> PEXPIREAT runoobkey 1555555555005
(integer) 1

KEYS

KEYS pattern

查找所有符合给定模式( pattern)的 key 。

首先创建一些 key,并赋上对应值:

127.0.0.1:6379> SET runoob1 redis
OK
127.0.0.1:6379> SET runoob2 mysql
OK
127.0.0.1:6379> SET runoob3 mongodb
OK

查找以 runoob 为开头的 key:

127.0.0.1:6379> keys runoob*
1) "runoob3"
2) "runoob2"
3) "runoob1"

获取 redis 中所有的 key 可用使用 *。

 127.0.0.1:6379> KEYS *
1) "runoob3"
2) "runoob1"
3) "runoob2"

MOVE

MOVE key db

将当前数据库的 key 移动到给定的数据库 db 当中。

# key 存在于当前数据库

redis> SELECT 0                             # redis默认使用数据库 0,为了清晰起见,这里再显式指定一次。
OK redis> SET song "secret base - Zone"
OK redis> MOVE song 1 # 将 song 移动到数据库 1
(integer) 1 redis> EXISTS song # song 已经被移走
(integer) 0 redis> SELECT 1 # 使用数据库 1
OK redis:1> EXISTS song # 证实 song 被移到了数据库 1 (注意命令提示符变成了"redis:1",表明正在使用数据库 1)
(integer) 1 # 当 key 不存在的时候 redis:1> EXISTS fake_key
(integer) 0 redis:1> MOVE fake_key 0 # 试图从数据库 1 移动一个不存在的 key 到数据库 0,失败
(integer) 0 redis:1> select 0 # 使用数据库0
OK redis> EXISTS fake_key # 证实 fake_key 不存在
(integer) 0 # 当源数据库和目标数据库有相同的 key 时 redis> SELECT 0 # 使用数据库0
OK
redis> SET favorite_fruit "banana"
OK redis> SELECT 1 # 使用数据库1
OK
redis:1> SET favorite_fruit "apple"
OK redis:1> SELECT 0 # 使用数据库0,并试图将 favorite_fruit 移动到数据库 1
OK redis> MOVE favorite_fruit 1 # 因为两个数据库有相同的 key,MOVE 失败
(integer) 0 redis> GET favorite_fruit # 数据库 0 的 favorite_fruit 没变
"banana" redis> SELECT 1
OK redis:1> GET favorite_fruit # 数据库 1 的 favorite_fruit 也是
"apple"

PERSIST

PERSIST key

移除 key 的过期时间,key 将持久保持。

redis> SET mykey "Hello"
OK redis> EXPIRE mykey 10 # 为 key 设置生存时间
(integer) 1 redis> TTL mykey
(integer) 10 redis> PERSIST mykey # 移除 key 的生存时间
(integer) 1 redis> TTL mykey
(integer) -1

PTTL

PTTL key

以毫秒为单位返回 key 的剩余的过期时间。

返回值

当 key 不存在时,返回 -2 。 当 key 存在但没有设置剩余生存时间时,返回 -1 。 否则,以毫秒为单位,返回 key 的剩余生存时间。

注意:在 Redis 2.8 以前,当 key 不存在,或者 key 没有设置剩余生存时间时,命令都返回 -1 。

# 不存在的 key

redis> FLUSHDB
OK redis> PTTL key
(integer) -2 # key 存在,但没有设置剩余生存时间 redis> SET key value
OK redis> PTTL key
(integer) -1 # 有剩余生存时间的 key redis> PEXPIRE key 10086
(integer) 1 redis> PTTL key
(integer) 6179

TTL

TTL key

以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。

# 不存在的 key

redis> FLUSHDB
OK redis> TTL key
(integer) -2 # key 存在,但没有设置剩余生存时间 redis> SET key value
OK redis> TTL key
(integer) -1 # 有剩余生存时间的 key redis> EXPIRE key 10086
(integer) 1 redis> TTL key
(integer) 10084

RANDOMKEY

RANDOMKEY

从当前数据库中随机返回一个 key 。

# 数据库不为空

redis> MSET fruit "apple" drink "beer" food "cookies"   # 设置多个 key
OK redis> RANDOMKEY
"fruit" redis> RANDOMKEY
"food" redis> KEYS * # 查看数据库内所有key,证明 RANDOMKEY 并不删除 key
1) "food"
2) "drink"
3) "fruit" # 数据库为空 redis> FLUSHDB # 删除当前数据库所有 key
OK redis> RANDOMKEY
(nil)

RENAME

RENAME oldkey newkey

修改 key 的名称

返回值

改名成功时提示 OK ,失败时候返回一个错误。

当 oldkey 和 newkey 相同,或者 oldkey 不存在时,返回一个错误。 当 newkey 已经存在时, RENAME 命令将覆盖旧值。

# key 存在且 newkey 不存在

redis> SET message "hello world"
OK redis> RENAME message greeting
OK redis> EXISTS message # message 不复存在
(integer) 0 redis> EXISTS greeting # greeting 取而代之
(integer) 1 # 当 key 不存在时,返回错误 redis> RENAME fake_key never_exists
(error) ERR no such key # newkey 已存在时, RENAME 会覆盖旧 newkey redis> SET pc "lenovo"
OK redis> SET personal_computer "dell"
OK redis> RENAME pc personal_computer
OK redis> GET pc
(nil) redis:1> GET personal_computer # 原来的值 dell 被覆盖了
"lenovo"

RENAMENX

RENAMENX oldkey newkey

仅当 newkey 不存在时,将 oldkey 改名为 newkey 。

# newkey 不存在,改名成功

redis> SET player "MPlyaer"
OK redis> EXISTS best_player
(integer) 0 redis> RENAMENX player best_player
(integer) 1 # newkey存在时,失败 redis> SET animal "bear"
OK redis> SET favorite_animal "butterfly"
OK redis> RENAMENX animal favorite_animal
(integer) 0 redis> get animal
"bear" redis> get favorite_animal
"butterfly"

RENAME 与 RENAMENX 区别

相同:

newkey 不存在

RENAMERENAMENX一样:oldkey删除

不同:

newkey 已存在时

RENAME 会覆盖旧 newkey,RENAMENX 失败。

TYPE

TYPE key

返回 key 所储存的值的类型。

# 字符串

redis> SET weather "sunny"
OK redis> TYPE weather
string # 列表 redis> LPUSH book_list "programming in scala"
(integer) 1 redis> TYPE book_list
list # 集合 redis> SADD pat "dog"
(integer) 1 redis> TYPE pat
set

参考

runoob,Redis 键(key)

Redis实战 - 4.Key的更多相关文章

  1. C# Redis实战(二) [转]

    二.Redis服务  在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图               ...

  2. (转)国内外三个不同领域巨头分享的Redis实战经验及使用场景

    随着应用对高性能需求的增加,NoSQL逐渐在各大名企的系统架构中生根发芽.这里我们将为大家分享社交巨头新浪微博.传媒巨头Viacom及图片分享领域佼佼者Pinterest带来的Redis实践,首先我们 ...

  3. C# Redis实战

    转自  :http://blog.csdn.net/qiujialongjjj/article/details/16945569 一.初步准备 Redis 是一个开源的使用ANSI C 语言编写.支持 ...

  4. Redis实战之征服 Redis + Jedis + Spring (一)

    Redis + Jedis + Spring (一)—— 配置&常规操作(GET SET DEL)接着需要快速的调研下基于Spring框架下的Redis操作. 相关链接: Redis实战 Re ...

  5. Redis实战之征服 Redis + Jedis + Spring (二)

    不得不说,用哈希操作来存对象,有点自讨苦吃! 不过,既然吃了苦,也做个记录,也许以后API升级后,能好用些呢?! 或许,是我的理解不对,没有真正的理解哈希表. 相关链接: Redis实战 Redis实 ...

  6. Redis实战之征服 Redis + Jedis + Spring (三)

    一开始以为Spring下操作哈希表,列表,真就是那么土.恍惚间发现“stringRedisTemplate.opsForList()”的强大,抓紧时间恶补下. 通过spring-data-redis完 ...

  7. C# Redis实战(七)

    七.修改数据 在上一篇 C# Redis实战(六)中介绍了如何查询Redis中数据,本篇将介绍如何修改Redis中相关数据.大家都知道Redis是key-value型存储系统,所以应该可以修改key, ...

  8. C# Redis实战(六)

    六.查询数据 在C# Redis实战(五)中介绍了如何删除Redis中数据,本篇将继续介绍Redis中查询的写法. 1.使用Linq匹配关键字查询 using (var redisClient = R ...

  9. C# Redis实战(二)

    二.Redis服务  在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图             可以 ...

随机推荐

  1. mysql的服务器构成

    什么是实例 这里的实例不是类产生的实例对象,而是Linux系统下的一种机制 1.MySQL的后台进程+线程+预分配的内存结构. 2.MySQL在启动的过程中会启动后台守护进程,并生成工作线程,预分配内 ...

  2. python第六天

    深浅拷贝,元祖,字典 ,集合的定义以及基本操作方法 深浅拷贝 # 值拷贝:应用场景最多​值拷贝:先创建一个列表ls = [1, 'abc', [10]] 再定义 ls1 = ls  此处ls1会直接将 ...

  3. python+appium模拟手机物理按键操作

    一句代码:driver.keyevent()        括号里填入的是手机物理按键的数字代号 driver.press_keycode()        括号里填入的是键盘按键的数字代号 手机物理 ...

  4. (二叉树 递归) leetcode94. Binary Tree Inorder Traversal

    Given a binary tree, return the inorder traversal of its nodes' values. Example: Input: [1,null,2,3] ...

  5. vue-输入框change事件并获取值

    1.html <input type="text" @change="specifiName($event)" /> 2.js var vm = n ...

  6. CSS3总结一:border(边框)

    Border-CSS1的属性 Border-CSS1:border Border-CSS1:border-style Border-CSS1:border-width Border-CSS1:bord ...

  7. DirectX11--HR宏关于dxerr库的替代方案

    DirectX11 With Windows SDK完整目录 欢迎加入QQ群: 727623616 可以一起探讨DX11,以及有什么问题也可以在这里汇报. 综述 参考文章:https://blogs. ...

  8. Q查询条件

    e. Q查询 ``` def search(self, query_list): query = self.request.GET.get('query', '') # 获取query的值 # Q(Q ...

  9. 分布式系列十: Redis安装和命令

    redis是一个开源的, 内存数据结构存储, 一般用来作为数据库,缓存和消息代理. Redis的优势 多种数据结构 字符类型String 散列类型Hash 列表类型List 集合类型Set 有序集合类 ...

  10. day04 流程控制

    在python中流程控制主要有三种:顺序流程.分支流程.循环流程 1.顺序流程:在宏观上,python程序的运行就是自上而下的顺序流程: 2.分支流程:分支流程主要是  if...else....流程 ...