您的位置:首页 > 数据库 > Redis

redis TTL使用

2016-11-28 13:22 99 查看
项目里面需要删除超过一周的数据,想到了下redis TTL功能。

127.0.0.1:6379> set gtf "gtfaww"

OK

127.0.0.1:6379> EXPIRE gtf 600

(integer) 1

127.0.0.1:6379> ttl gtf

(integer) 594

127.0.0.1:6379> ttl gtf

(integer) 549

127.0.0.1:6379> PERSIST gtf   ##重新把key变为持久的

(integer) 1

127.0.0.1:6379> ttl gtf

(integer) -1

127.0.0.1:6379> get gtf

"gtfaww"

127.0.0.1:6379> SETEX gtf 600 "gtaww1"   ##设置键的同时设定过期时间(秒)

OK

127.0.0.1:6379> ttl gtf

(integer) 595

127.0.0.1:6379> get gtf

"gtaww1"

127.0.0.1:6379> 

注意:

生存时间可以通过使用 DEL 命令来删除整个 key 来移除,或者被 SET 和 GETSET 命令覆写(overwrite),这意味着,如果一个命令只是修改(alter)一个带生存时间的 key 的值而不是用一个新的 key 值来代替(replace)它的话,那么生存时间不会被改变。

比如说,对一个 key 执行 INCR 命令,对一个列表进行 LPUSH 命令,或者对一个哈希表执行 HSET 命令,这类操作都不会修改 key 本身的生存时间。

127.0.0.1:6379> setex gtf1 600 10

OK

127.0.0.1:6379> ttl gtf1

(integer) 592

127.0.0.1:6379> INCR gtf1 

(integer) 11

127.0.0.1:6379> ttl gtf1

(integer) 579

127.0.0.1:6379> 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  redis ttl