Redis目前已经支持多种丰富的数据类型,从本章节开始将详细说明各种数据类型。
字符串(String)
String 数据类型结构为 Key-Value 形式,其中Value可以是字符串、数字,也可以是二进制数组,
它的限制是Value最大值为512MB。
示例
127.0.0.1:6379> set a hello
OK
127.0.0.1:6379> get a
"hello"
127.0.0.1:6379>
关于string的常用命令
下表列出了常用的 redis 字符串命令:
命令 | 说明 |
---|---|
SET key value | 设置指定 key 的值 |
GET key | 获取指定 key 的值 |
GETRANGE key start end | 返回 key 中字符串值的子字符 |
GETSET key value | 将给定 key 的值设为 value ,并返回 key 的旧值(old value) |
GETBIT key offset | 对 key 所储存的字符串值,获取指定偏移量上的位(bit) |
MGET key1 [key2…] | 获取所有(一个或多个)给定 key 的值 |
SETBIT key offset value | 对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit) |
SETEX key seconds value | 将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)。 |
SETNX key value | 只有在 key 不存在时设置 key 的值 |
SETRANGE key offset value | 用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始。 |
STRLEN key | 返回 key 所储存的字符串值的长度 |
MSET key value [key value …] | 同时设置一个或多个 key-value 对 |
MSETNX key value [key value …] | 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在 |
PSETEX key milliseconds value | 这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位 |
INCR key | 将 key 中储存的数字值增一 |
INCRBY key increment | 将 key 所储存的值加上给定的增量值(increment) |
INCRBYFLOAT key increment | 将 key 所储存的值加上给定的浮点增量值(increment) |
DECR key | 将 key 中储存的数字值减一 |
DECRBY key decrement | key 所储存的值减去给定的减量值(decrement) |
APPEND key value | 如果 key 已经存在并且是一个字符串, APPEND 命令将指定的 value 追加到该 key 原来值(value)的末尾 |
get 和 mget 的区别
由于 redis 存储在内存中,所以执行命令的速度很快,即命令时间相差不大,但是网络时间涉及到网速快慢的问题,明显 mget 只请求一次网络的时间比 get 方法请求多次网络的时间开销小,效率也更高。对比如下:
Redis 哈希(Hash)
Redis hash 是一个 string 类型的 field(字段) 和 value(值) 的映射表,hash 数据类型特别适合用于存储对象。Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。它的结构如下:
示例
127.0.0.1:6379> HMSET yonghu1 name 'xiaoming' age 20 height 180 weight 75kg
OK
127.0.0.1:6379> HGETALL yonghu1
1) "name"
2) "xiaoming"
3) "age"
4) "20"
5) "height"
6) "180"
7) "weight"
8) "75kg"
127.0.0.1:6379>
关于hash的常用命令
下表列出了 redis hash 基本的相关命令:
命令 | 说明 |
---|---|
HDEL key field1 [field2] | 删除一个或多个哈希表字段 |
HEXISTS key field | 查看哈希表 key 中,指定的字段是否存在 |
HGET key field | 获取存储在哈希表中指定字段的值 |
HGETALL key | 获取在哈希表中指定 key 的所有字段和值 |
HINCRBY key field increment | 为哈希表 key 中的指定字段的整数值加上增量 increment |
HINCRBYFLOAT key field increment | 为哈希表 key 中的指定字段的浮点数值加上增量 increment |
HKEYS key | 获取哈希表中的所有字段 |
HLEN key | 获取哈希表中字段的数量 |
HMGET key field1 [field2] | 获取所有给定字段的值 |
HMSET key field1 value1 [field2 value2 ] | 同时将多个 field-value (域-值)对设置到哈希表 key 中 |
HSET key field value | 将哈希表 key 中的字段 field 的值设为 value |
HSETNX key field value | 只有在字段 field 不存在时,设置哈希表字段的值 |
HVALS key | 获取哈希表中所有值 |
HSCAN key cursor [MATCH pattern] [COUNT count] | 迭代哈希表中的键值对 |
Redis 列表(List)
Redis列表是简单的字符串列表,按照插入顺序排序。我们可以添加一个元素到列表的头部(左边)或者尾部(右边)。一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。在列表中,有索引的相关概念,如下:
- 索引从左往右,从0开始逐个增大 0 1 2 3 4 5
- 索引从右往左,从-1开始逐个减小 -6 -5 -4 -3 -2 -1
示例
127.0.0.1:6379> LPUSH list1 apple
(integer) 1
127.0.0.1:6379> LPUSH list1 banana
(integer) 2
127.0.0.1:6379> LPUSH list1 orange
(integer) 3
127.0.0.1:6379> LLEN list1
(integer) 3
127.0.0.1:6379> LRANGE list1 0 2
1) "orange"
2) "banana"
3) "apple"
在以上示例中我们使用了 LPUSH 将三个值插入了名为 list1
这个列表当中。
关于list的常用命令
下表列出了Redis 列表相关的基本命令:
命令 | 说明 |
---|---|
BLPOP key1 [key2 ] timeout | 移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。注意和LPOP的区别 |
BRPOP key1 [key2 ] timeout | 移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
BRPOPLPUSH source destination timeout | 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
LINDEX key index | 通过索引获取列表中的元素 |
LINSERT key BEFORE AFTER pivot value | 在列表的元素前或者后插入元素 |
LLEN key | 获取列表长度 |
LPOP key | 移出并获取列表的第一个元素 |
LPUSH key value1 [value2] | 将一个或多个值插入到列表头部 |
LPUSHX key value | 将一个值插入到已存在的列表头部,注意和LPUSH的区别,后者需要列表已经存在 |
LRANGE key start stop | 获取列表指定范围内的元素 |
LREM key count value | 移除列表元素 |
LSET key index value | 通过索引设置列表元素的值 |
LTRIM key start stop | 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。 |
RPOP key | 移除列表的最后一个元素,返回值为移除的元素。 |
RPOPLPUSH source destination | 移除列表的最后一个元素,并将该元素添加到另一个列表并返回 |
RPUSH key value1 [value2] | 在列表中添加一个或多个值到列表尾部 |
RPUSHX key value | 为已存在的列表添加值,注意和RPUSH的区别,后者也需要列表已经存在 |
实际使用中,当我们想实现一些功能的时候,可以结合各种命令组合使用。如:
- LRUSH + LPOP = Stack (实现栈,后进先出)
- LPUSH + RPOP = Queue (实现队列,先进先出)
- LPUSH + LTRIM = Capped Collection (实现有固定数量的列表)
- LPUSH + BRPOP = Message Queue (实现消息队列,阻塞等待)
Redis 集合(Set)
Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不会出现重复的数据。集合对象的编码可以是 intset 或者 hashtable。Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
示例
127.0.0.1:6379> SADD a zookeeper
(integer) 1
127.0.0.1:6379> SADD a kafka
(integer) 1
127.0.0.1:6379> SADD a mysql
(integer) 1
127.0.0.1:6379> SADD a mysql
(integer) 0
127.0.0.1:6379> SMEMBERS a
1) "mysql"
2) "zookeeper"
3) "kafka"
127.0.0.1:6379>
在以上实例中我们通过 SADD 命令向名为 a 集合中插入了三个元素。
关于set集合的常用命令
下表列出了 Redis 集合基本命令:
命令 | 说明 |
---|---|
SADD key member1 [member2] | 向集合添加一个或多个成员 |
SCARD key | 获取集合的成员数 |
SDIFF key1 [key2] | 返回第一个集合与其他集合之间的差异。 |
SDIFFSTORE destination key1 [key2] | 返回给定所有集合的差集并存储在 destination 中 |
SINTER key1 [key2] | 返回给定所有集合的交集 |
SINTERSTORE destination key1 [key2] | 返回给定所有集合的交集并存储在 destination 中 |
SISMEMBER key member | 判断 member 元素是否是集合 key 的成员 |
SMEMBERS key | 返回集合中的所有成员 |
SMOVE source destination member | 将 member 元素从 source 集合移动到 destination 集合 |
SPOP key | 移除并返回集合中的一个随机元素 |
SRANDMEMBER key [count] | 返回集合中一个或多个随机数 |
SREM key member1 [member2] | 移除集合中一个或多个成员 |
SUNION key1 [key2] | 返回所有给定集合的并集 |
SUNIONSTORE destination key1 [key2] | 所有给定集合的并集存储在 destination 集合中 |
SSCAN key cursor [MATCH pattern] [COUNT count] | 迭代集合中的元素 |
实际使用中,当我们想实现一些功能的时候,可以使用以下命令。如:
- SADD = Tagging (用来存放标签)
- SPOP/SRANDMEMBER = Random item (用来做一些随机数操作)
- SADD + SINTER = Social Graph (用来做一些社交关系)
Redis 有序集合(sorted set)
Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
示例
127.0.0.1:6379> ZADD zset 1 zookeeper
(integer) 1
127.0.0.1:6379> ZADD zset 2 kafka
(integer) 1
127.0.0.1:6379> ZADD zset 3 mysql
(integer) 1
127.0.0.1:6379> ZADD zset 4 mysql
(integer) 0
127.0.0.1:6379> ZRANGE zset 0 10 WITHSCORES
1) "zookeeper"
2) "1"
3) "kafka"
4) "2"
5) "mysql"
6) "4"
在以上实例中我们通过命令 ZADD 向 zset 这个有序集合中添加了三个值并关联上分数,注意有个重复的值,但是它的score被更新了。
有序集合zset常用命令
下表列出了 redis 有序集合的基本命令:
序号 | 说明 |
---|---|
ZADD key score1 member1 [score2 member2] | 向有序集合添加一个或多个成员,或者更新已存在成员的分数 |
ZCARD key | 获取有序集合的成员数 |
ZCOUNT key min max | 计算在有序集合中指定区间分数的成员数 |
ZINCRBY key increment member | 有序集合中对指定成员的分数加上增量 increment |
ZINTERSTORE destination numkeys key [key …] | 计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 destination 中 |
ZLEXCOUNT key min max | 在有序集合中计算指定字典区间内成员数量 |
ZRANGE key start stop [WITHSCORES] | 通过索引区间返回有序集合指定区间内的成员 |
ZRANGEBYLEX key min max [LIMIT offset count] | 通过字典区间返回有序集合的成员 |
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] | 通过分数返回有序集合指定区间内的成员 |
ZRANK key member | 返回有序集合中指定成员的索引 |
ZREM key member [member …] | 移除有序集合中的一个或多个成员 |
ZREMRANGEBYLEX key min max | 移除有序集合中给定的字典区间的所有成员 |
ZREMRANGEBYRANK key start stop | 移除有序集合中给定的排名区间的所有成员 |
ZREMRANGEBYSCORE key min max | 移除有序集合中给定的分数区间的所有成员 |
ZREVRANGE key start stop [WITHSCORES] | 返回有序集中指定区间内的成员,通过索引,分数从高到低 |
ZREVRANGEBYSCORE key max min [WITHSCORES] | 返回有序集中指定分数区间内的成员,分数从高到低排序 |
ZREVRANK key member | 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序 |
ZSCORE key member | 返回有序集中,成员的分数值 |
ZUNIONSTORE destination numkeys key [key …] | 计算给定的一个或多个有序集的并集,并存储在新的 key 中 |
ZSCAN key cursor [MATCH pattern] [COUNT count] | 迭代有序集合中的元素(包括元素成员和元素分值) |
本章节就先分享redis中的以上5种数据类型,后续还会分享一些其他的数据类型。
更多关于redis的知识分享,请前往博客主页。编写过程中,难免出现差错,敬请指出