Redis 数据类型介绍

盛年不重来,一日难再晨,及时当勉励,岁月不待人。这篇文章主要讲述Redis 数据类型介绍相关的知识,希望能为你提供帮助。
Redis 数据类型参考资料:http://www.redis.cn/topics/data-types.html
相关命令参考: http://redisdoc.com/

类型 简介 特性 场景
String(字符串) 二进制安全 可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512M ---
Hash(字典) 键值对集合,即编程语言中的Map类型 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值(Memcached中需要取出整个字符串反序列化成对象修改完再序列化存回去) 存储、读取、修改用户属性
List(列表) 链表(双向链表) 增删快,提供了操作某一段元素的API 1,最新消息排行等功能(比如朋友圈的时间线) 2,消息队列
Set(集合) 哈希表实现,元素不重复 1、添加、删除,查找的复杂度都是O(1) 2、为集合提供了求交集、并集、差集等操作 1、共同好友 2、利用唯一性,统计访问网站的所有独立ip 3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐
Sorted Set(有序集合) 将Set中的元素增加一个权重参数score,元素按score有序排列 数据插入集合时,已经进行天然排序 1、排行榜 2、带权重的消息队列
1.1 String(字符串)
字符串是所有编程语言中最常见的和最常用的数据类型,而且也是redis最基本的数据类型之一,而且redis 中所有的 key 的类型都是字符串。常用于保存 Session 信息场景,此数据类型比较常用
命令 含义 复杂度
Set key value 设置key-value o(1)
Get key 获取key-value o(1)
Del key 删除key-value o(1)
Setnx setxx 根据key是否存在设置key-value o(1)
Incr decr 计数 o(1)
Mget mset 批量操作key-value o(n)
1.1.1 添加key
  • set 指令可以创建一个key 并赋值, 使用格式
SET key value [EX seconds] [PX milliseconds] [NX|XX] 时间复杂度: O(1) 将字符串值 value 关联到 key 。如果 key 已经持有其他值, SET 就覆写旧值, 无视类型。 当 SET 命令对一个带有生存时间(TTL)的键进行设置之后, 该键原有的 TTL 将被清除。从 Redis 2.6.12 版本开始, SET 命令的行为可以通过一系列参数来修改: EX seconds : 将键的过期时间设置为 seconds 秒。 执行 SET key value EX seconds 的效果等 同于执行 SETEX key seconds value 。 PX milliseconds : 将键的过期时间设置为 milliseconds 毫秒。 执行 SET key value PX milliseconds 的效果等同于执行 PSETEX key milliseconds value 。 NX : 只在键不存在时, 才对键进行设置操作。 执行 SET key value NX 的效果等同于执行 SETNX key value 。 XX : 只在键已经存在时, 才对键进行设置操作。

  • 范例
#不论key是否存在.都设置 127.0.0.1:6379> set key1 value1 OK 127.0.0.1:6379> get key1 "value1" 127.0.0.1:6379> TYPE key1 #判断类型 string 127.0.0.1:6379> SET title ceo ex 3 #设置自动过期时间3s OK 127.0.0.1:6379> set NAME wang OK 127.0.0.1:6379> get NAME "wang" #大小写敏感 127.0.0.1:6379> get name (nil) 127.0.0.1:6379> set name mage OK 127.0.0.1:6379> get name "mage" 127.0.0.1:6379> get NAME "wang" #key不存在,才设置,相当于add 127.0.0.1:6379> get title "ceo" 127.0.0.1:6379> setnx title coo #set key value nx (integer) 0 127.0.0.1:6379> get title "ceo" #key存在,才设置,相当于update 127.0.0.1:6379> get title "ceo" 127.0.0.1:6379> set title coo xx OK 127.0.0.1:6379> get title "coo" 127.0.0.1:6379> get age (nil) 127.0.0.1:6379> set age 20 xx (nil) 127.0.0.1:6379> get age (nil)

1.1.2 获取key内容
127.0.0.1:6379> get key1 "value1" 127.0.0.1:6379> get name age (error) ERR wrong number of arguments for \'get\' command

1.1.3 删除key
127.0.0.1:6379> DEL key1 (integer) 1 127.0.0.1:6379> DEL key1 key2 (integer) 2

1.1.4 批量设置多个key
127.0.0.1:6379> MSET key1 value1 key2 value2 OK

1.1.5 批量获取多个key
127.0.0.1:6379> MGET key1 key2 1) "value1" 2) "value2" 127.0.0.1:6379> KEYS n* 1) "n1" 2) "name" 127.0.0.1:6379> KEYS * 1) "k2" 2) "k1" 3) "key1" 4) "key2" 5) "n1" 6) "name" 7) "k3" 8) "title"

1.1.6 追加数据
127.0.0.1:6379> APPEND key1 " append new value" (integer) 12 #添加数据后,key1总共9个字节 127.0.0.1:6379> get key1 "value1 append new value"

1.1.7 设置新值并返回旧值
#set key newvalue并返回旧的value 127.0.0.1:6379> set name wang OK 127.0.0.1:6379> getset name 123 "wang" 127.0.0.1:6379> get name "test"

1.1.8 返回字符串key对应的字节数
127.0.0.1:6379> SET name wang OK 127.0.0.1:6379> STRLEN name (integer) 4 127.0.0.1:6379> APPEND name " xiaochun" (integer) 13 127.0.0.1:6379> GET name "wang xiaochun" 127.0.0.1:6379> STRLEN name #返回字节数 (integer) 13 127.0.0.1:6379> set name test OK 127.0.0.1:6379> get name "\\xe9\\xa9\\xac\\xe5\\x93\\xa5\\xe6\\x95\\x99\\xe8\\x82\\xb2" 127.0.0.1:6379> strlen name (integer) 12 127.0.0.1:6379>

1.1.9 判断key是否存在
127.0.0.1:6379> SET name wang ex 10 OK 127.0.0.1:6379> set age 20 OK 127.0.0.1:6379> EXISTS NAME #key的大小写敏感 (integer) 0 127.0.0.1:6379> EXISTS name age #返回值为1,表示存在2个key,0表示不存在 (integer) 2 127.0.0.1:6379> EXISTS name #过几秒再看 (integer) 0

1.1.10 查看key过期时间
ttl key #查看key的剩余生存时间,如果key过期后,会自动删除 -1 #返回值表示永不过期,默认创建的key是永不过期,重新对key赋值,也会从有剩余生命周期变成永不过 期 -2 #返回值表示没有此key num #key的剩余有效期 127.0.0.1:6379> TTL key1 (integer) -1 127.0.0.1:6379> SET name wang EX 100 OK 127.0.0.1:6379> TTL name (integer) 96 127.0.0.1:6379> TTL name (integer) 93 127.0.0.1:6379> SET name OK mage #重新设置,默认永不过期 127.0.0.1:6379> TTL name (integer) -1 127.0.0.1:6379> SET name wang EX 200 OK 127.0.0.1:6379> TTL name (integer) 198 127.0.0.1:6379> GET name "wang"

1.1.11 重新设置key的过期时间
127.0.0.1:6379> TTL name (integer) 148 127.0.0.1:6379> EXPIRE name 1000 (integer) 1 127.0.0.1:6379> TTL name (integer) 999 127.0.0.1:6379>

1.1.12 取消key的过期时间
127.0.0.1:6379> TTL name (integer) 999 127.0.0.1:6379> PERSIST name (integer) 1 127.0.0.1:6379> TTL name (integer) -1

1.1.13 数值递增
  • 利用INCR命令簇(INCR, DECR, INCRBY,DECRBY)来把字符串当作原子计数器使用。
127.0.0.1:6379> set num 10 #设置初始值 OK 127.0.0.1:6379> INCR num (integer) 11 127.0.0.1:6379> get num "11"

1.1.14 数值递减
127.0.0.1:6379> set num 10 OK 127.0.0.1:6379> DECR num (integer) 9 127.0.0.1:6379> get num "9"

1.1.15 数值增加
  • 将key对应的数字加decrement(可以是负数)。如果key不存在,操作之前,key就会被置为0。如果key 的value类型错误或者是个不能表示成数字的字符串,就返回错误。这个操作最多支持64位有符号的正 型数字。
redis> SET mykey 10 OK redis> INCRBY mykey 5 (integer) 15 127.0.0.1:6379> get mykey "15" 127.0.0.1:6379> INCRBY mykey -10 (integer) 5 127.0.0.1:6379> get mykey "5" 127.0.0.1:6379> INCRBY nokey5 (integer) 5 127.0.0.1:6379> get nokey "5"

1.1.16 数据减少
  • decrby 可以减小数值(也可以增加)
127.0.0.1:6379> SET mykey 10 OK 127.0.0.1:6379> DECRBY mykey 8 (integer) 2 127.0.0.1:6379> get mykey "2" 127.0.0.1:6379> DECRBY mykey -20 (integer) 22 127.0.0.1:6379> get mykey "22" 127.0.0.1:6379> DECRBY nokey 3 (integer) -3 127.0.0.1:6379> get nokey "-3"

1.5.2 列表 list
Redis 数据类型介绍

文章图片

  • 列表是一个双向可读写的管道,其头部是左侧,尾部是右侧,一个列表最多可以包含2^32- 1(4294967295)个元素,下标 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。 也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,元素值可以重 复,常用于存入日志等场景,此数据类型比较常用
  • 列表特点
    • 有序
    • 可重复
    • 左右都可操作
1.5.2.1生成列表并插入数据
  • LPUSH和RPUSH都可以插入列表
LPUSH key value [value …] 时间复杂度: O(1) 将一个或多个值 value 插入到列表 key 的表头如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表头: 比如说,对空列表 mylist 执行命令 LPUSH mylist a b c ,列表的值将是 c b a ,这等同于原子性地执行 LPUSH mylist a 、 LPUSH mylist b 和 LPUSH mylist c 三个命令。如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。 当 key 存在但不是列表类型时,返回一个错误。 RPUSH key value [value …] 时间复杂度: O(1) 将一个或多个值 value 插入到列表 key 的表尾(最右边)。如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表尾:比如对一个空列表 mylist 执行 RPUSH mylist a b c ,得出的结果列表为 a b c ,等同于执行命令 RPUSH mylist a 、 RPUSH mylist b 、 RPUSH mylist c 。如果 key 不存在,一个空列表会被创建并执行 RPUSH 操作。 当 key 存在但不是列表类型时,返回一个错误。

  • 范例
#从左边添加数据,已添加的需向右移 127.0.0.1:6379> LPUSH name mage wang zhang #根据顺序逐个写入name,最后的zhang会在列表的最左侧。 (integer) 3 127.0.0.1:6379> TYPE name list#从右边添加数据 127.0.0.1:6379> RPUSH course linux python go (integer) 3 127.0.0.1:6379> type course list

1.5.2.2向列表追加数据
127.0.0.1:6379> LPUSH list1 tom (integer) 2 #从右边添加数据,已添加的向左移 127.0.0.1:6379> RPUSH list1 jack (integer) 3

1.5.2.3 获取列表长度(元素个数)
127.0.0.1:6379> LLEN list1 (integer) 3

1.5.2.4 获取列表指定位置数据【Redis 数据类型介绍】
Redis 数据类型介绍

文章图片

Redis 数据类型介绍

文章图片

Redis 数据类型介绍

文章图片

127.0.0.1:6379> LPUSH list1 a b c d (integer) 4 127.0.0.1:6379> LINDEX list1 0 #获取0编号的元素 "d" 127.0.0.1:6379> LINDEX list1 3 #获取3编号的元素 "a" 127.0.0.1:6379> LINDEX list1 -1 #获取最后一个的元素 "a" #元素从0开始编号 127.0.0.1:6379> LPUSH list1 a b c d (integer) 4 127.0.0.1:6379> LRANGE list1 1 2 1) "c" 2) "b" 127.0.0.1:6379> LRANGE list1 0 3 #所有元素 1) "d" 2) "c" 3) "b" 4) "a" 127.0.0.1:6379> LRANGE list1 0 -1 #所有元素 1) "d" 2) "c" 3) "b" 4) "a"127.0.0.1:6379> RPUSH list2 zhang wang li zhao (integer) 4 127.0.0.1:6379> LRANGE list2 1 2 #指定范围 1) "wang" 2) "li" 127.0.0.1:6379> LRANGE list2 2 2 #指定位置 1) "li" 127.0.0.1:6379> LRANGE list2 0 -1 #所有元素 1) "zhang" 2) "wang" 3) "li" 4) "zhao"

1.5.2.5 获取列表指定索引值
127.0.0.1:6379> RPUSH listkey a b c d e f (integer) 6 127.0.0.1:6379> lrange listkey 0 -1 1) "a" 2) "b" 3) "c" 4) "d" 5) "e" 6) "f" 127.0.0.1:6379> lset listkey 2 java OK 127.0.0.1:6379> lrange listkey 0 -1 1) "a" 2) "b" 3) "java" 4) "d" 5) "e" 6) "f" 127.0.0.1:6379>

1.5.2.6 移除列表数据
127.0.0.1:6379> LPUSH list1 a b c d (integer) 4 127.0.0.1:6379> LRANGE list1 0 3 1) "d" 2) "c" 3) "b" 4) "a" 127.0.0.1:6379> LPOP list1 #弹出左边第一个元素,即删除第一个 "d" 127.0.0.1:6379> LLEN list1 (integer) 3 127.0.0.1:6379> LRANGE list1 0 2 1) "c" 2) "b" 3) "a" 127.0.0.1:6379> RPOP list1 #弹出右边第一个元素,即删除最后一个 "a" 127.0.0.1:6379> LLEN list1 (integer) 2 127.0.0.1:6379> LRANGE list1 0 1 1) "c" 2) "b"#LTRIM 对一个列表进行修剪(trim),让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删 除 127.0.0.1:6379> LLEN list1 (integer) 4 127.0.0.1:6379> LRANGE list1 0 3 1) "d" 2) "c" 3) "b" 4) "a" 127.0.0.1:6379> LTRIM list1 1 2 #只保留1,2号元素 OK 127.0.0.1:6379> LLEN list1 (integer) 2 127.0.0.1:6379> LRANGE list1 0 1 1) "c" 2) "b" #删除list 127.0.0.1:6379> DEL list1 (integer) 1 127.0.0.1:6379> EXISTS list1 (integer) 0

1.5.3 集合setSet 是 String 类型的无序集合,集合中的成员是唯一的,这就意味着集合中不能出现重复的数据,可以
在两个不同的集合中对数据进行对比并取值,常用于取值判断,统计,交集等场景
集合特点
  • 无序
  • 无重复
  • 集合间操作
1.5.3.1 生成集合key
127.0.0.1:6379> SADD set1 v1 (integer) 1 127.0.0.1:6379> SADD set2 v2 v4 (integer) 2 127.0.0.1:6379> TYPE set1 set 127.0.0.1:6379> TYPE set2 set

1.5.3.2 追加数值
#追加时,只能追加不存在的数据,不能追加已经存在的数值 127.0.0.1:6379> SADD set1 v2 v3 v4 (integer) 3 127.0.0.1:6379> SADD set1 v2 #已存在的value,无法再次添加 (integer) 0 127.0.0.1:6379> TYPE set1 set 127.0.0.1:6379> TYPE set2 set

1.5.3.3 查看集合的所有数据
127.0.0.1:6379> SMEMBERS set1 1) "v4" 2) "v1" 3) "v3" 4) "v2" 127.0.0.1:6379> SMEMBERS set2 1) "v4" 2) "v2"

1.5.3.4 删除集合的元素
127.0.0.1:6379> sadd goods mobile laptop car (integer) 3 127.0.0.1:6379> srem goods car (integer) 1 127.0.0.1:6379> SMEMBERS goods 1) "mobile" 2) "laptop" 127.0.0.1:6379>

1.5.3.5 获取集合的交集
  • 交集:已属于A且属于B的元素称为A与B的交(集
127.0.0.1:6379> SINTER set1 set2 1) "v4" 2) "v2"

1.5.3.6 获取集合的并集
  • 并集:已属于A或属于B的元素为称为A与B的并(集)
127.0.0.1:6379> SUNION set1 set2 1) "v2" 2) "v4" 3) "v1" 4) "v3"

1.5.3.7 获取集合的差集
  • 差集:已属于A而不属于B的元素称为A与B的差(集)
127.0.0.1:6379> SDIFF set1 set2 1) "v1" 2) "v3"

1.5.4 有序集合 sorted set
  • Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员,不同的是每个元素都会关
    联一个double(双精度浮点型)类型的分数,redis正是通过该分数来为集合中的成员进行从小到大的排
    序,有序集合的成员是唯一的,但分数(score)却可以重复,集合是通过哈希表实现的,所以添加,删
    除,查找的复杂度都是O(1), 集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个
    成员),经常用于排行榜的场景
  • 有序集合特点
    • 有序
    • 无重复元素
    • 每个元素是由score和value组成
    • score 可以重复
    • value 不可以重复
1.5.4.1 生成有序集合
127.0.0.1:6379> ZADD zset1 1 v1 #分数为1 (integer) 1 127.0.0.1:6379> ZADD zset1 2 v2 (integer) 1 127.0.0.1:6379> ZADD zset1 2 v3 #分数可重复,元素值不可以重复 (integer) 1 127.0.0.1:6379> ZADD zset1 3 v4 (integer) 1 127.0.0.1:6379> TYPE zset1 zset 127.0.0.1:6379> TYPE zset2 zset #一次生成多个数据: 127.0.0.1:6379> ZADD zset2 1 v1 2 v2 3 v3 4 v4 5 v5 (integer) 5

1.5.4.2 有序集合实现排行榜
127.0.0.1:6379> ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia (integer) 4 127.0.0.1:6379> ZRANGE paihangbang 0 -1 #正序排序后显示集合内所有的key,score从小到大 显示 1) "gangtiexia" 2) "zhuluoji" 3) "nezha" 4) "zhanlang" 127.0.0.1:6379> ZREVRANGE paihangbang 0 -1 #倒序排序后显示集合内所有的key,score从大到 小显示 1) "zhanlang" 2) "nezha" 3) "zhuluoji" 4) "gangtiexia" 127.0.0.1:6379> ZRANGE paihangbang 0 -1 WITHSCORES #正序显示指定集合内所有key和得分 情况 1) "gangtiexia" 2) "30" 3) "zhuluoji" 4) "60" 5) "nezha" 6) "90" 7) "zhanlang" 8) "199" 127.0.0.1:6379> ZREVRANGE paihangbang 0 -1 WITHSCORES #倒序显示指定集合内所有key和 得分情况 1) "zhanlang" 2) "199" 3) "nezha" 4) "90" 5) "zhuluoji" 6) "60" 7) "gangtiexia" 8) "30" 127.0.0.1:6379>

1.5.4.3 获取集合的个数
127.0.0.1:6379> ZCARD paihangbang (integer) 4 127.0.0.1:6379> ZCARD zset1 (integer) 4 127.0.0.1:6379> ZCARD zset2 (integer) 4

1.5.4.4 基于索引返回数值
127.0.0.1:6379> ZRANGE paihangbang 0 2 1) "gangtiexia" 2) "zhuluoji" 3) "nezha" 127.0.0.1:6379> ZRANGE paihangbang 0 10 #超出范围不报错 1) "gangtiexia" 2) "zhuluoji" 3) "nezha" 4) "zhanlang" 127.0.0.1:6379> ZRANGE zset1 1 3 1) "v2" 2) "v3" 3) "v4" 127.0.0.1:6379> ZRANGE zset1 0 2 1) "v1" 2) "v2" 3) "v3" 127.0.0.1:6379> ZRANGE zset1 2 2 1) "v3"

1.5.4.5 返回某个数值的索引(排名)
127.0.0.1:6379> ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia (integer) 4 127.0.0.1:6379> ZRANK paihangbang zhanlang (integer) 3 #第4个 127.0.0.1:6379> ZRANK paihangbang zhuluoji (integer) 1 #第2个

1.5.4.6 获取分数
127.0.0.1:6379> zscore paihangbang gangtiexia "30"

1.5.4.7 删除元素
127.0.0.1:6379> ZADD paihangbang 90 nezha 199 zhanlang 60 zhuluoji 30 gangtiexia (integer) 4 127.0.0.1:6379> ZRANGE paihangbang 0 -1 1) "gangtiexia" 2) "zhuluoji" 3) "nezha" 4) "zhanlang" 127.0.0.1:6379> ZREM paihangbang zhuluoji zhanlang (integer) 2 127.0.0.1:6379> ZRANGE paihangbang 0 -1 1) "gangtiexia" 2) "nezha"

1.5.5 哈希hashhash 是一个string类型的字段(field)和值(value)的映射表,Redis 中每个 hash 可以存储 2^32 -1 键值
对,类似于字典,存放了多个k/v 对,hash特别适合用于存储对象场景
1.5.5.1 生成hash key
  • 格式:
HSET hash field value 时间复杂度: O(1) 将哈希表 hash 中域 field 的值设置为 value 。 如果给定的哈希表并不存在, 那么一个新的哈希表将被创建并执行 HSET 操作。 如果域 field 已经存在于哈希表中, 那么它的旧值将被新值 value 覆盖。

127.0.0.1:6379> HSET 9527 name zhouxingxing age 20 (integer) 2 127.0.0.1:6379> TYPE 9527 hash #查看所有字段的值 127.0.0.1:6379> hgetall 9527 1) "name" 2) "zhouxingxing" 3) "age" 4) "20" #增加字段 127.0.0.1:6379> HSET 9527 gender male (integer) 1 127.0.0.1:6379> hgetall 9527 1) "name" 2) "zhouxingxing" 3) "age" 4) "20" 5) "gender" 6) "male"

1.5.5.2 获取hash对应字段值
127.0.0.1:6379> HGET 9527 name "zhouxingxing" 127.0.0.1:6379> HGET 9527 age "20" 127.0.0.1:6379> HMGET 9527 name age #获取多个值 1) "zhouxingxing" 2) "20" 127.0.0.1:6379>

1.5.5.3 删除hash 对应字段
127.0.0.1:6379> HDEL 9527 age (integer) 1 127.0.0.1:6379> HGET 9527 age (nil) 127.0.0.1:6379> hgetall 9527 1) "name" 2) "zhouxingxing" 127.0.0.1:6379> HGET 9527 name "zhouxingxing"

1.5.5.4 批量设置hash key的多个field和value
127.0.0.1:6379> HMSET 9527 name zhouxingxing age 50 city hongkong OK 127.0.0.1:6379> HGETALL 9527 1) "name" 2) "zhouxingxing" 3) "age" 4) "50" 5) "city" 6) "hongkong"

1.5.5.5 获取hash中指定字段的值
127.0.0.1:6379> HMSET 9527 name zhouxingxing age 50 city hongkong OK 127.0.0.1:6379> HMGET 9527 name age 1) "zhouxingxing" 2) "50" 127.0.0.1:6379>

1.5.5.6 获取hash中的所有字段名field
127.0.0.1:6379> HMSET 9527 name zhouxingxing age 50 city hongkong #重新设置 OK 127.0.0.1:6379> HKEYS 9527 1) "name" 2) "age" 3) "city"

1.5.5.7 获取hash key对应所有field的value
127.0.0.1:6379> HMSET 9527 name zhouxingxing age 50 city hongkong OK 127.0.0.1:6379> HVALS 9527 1) "zhouxingxing" 2) "50" 3) "hongkong"

1.5.5.8 获取指定hash key 的所有field及value
127.0.0.1:6379> HGETALL 9527 1) "name" 2) "zhouxingxing" 3) "age" 4) "50" 5) "city" 6) "hongkong" 127.0.0.1:6379>

1.5.5.9 删除hash
127.0.0.1:6379> DEL 9527 (integer) 1 127.0.0.1:6379> HMGET 9527 name city 1) (nil) 2) (nil) 127.0.0.1:6379> EXISTS 9527 (integer) 0


    推荐阅读