Redis 数据类型

Redis支持五种数据类型:

  • string(字符串)
  • hash(哈希)
  • list(列表)
  • set(集合)
  • zset(sorted set:有序集合)

字符串就是最常用的一种,其它用的也很频繁; 现在很多公司后端开发有好多组合,也就是说 公司可能会把前端部分交给PHP部分来开发,后端高性能部分交给Java来开发,那这个时候为了能够 兼容PHP和Java,大家的数据类型都是统一用字符串的,如果是对象类型,那么就会把对象转成 Json 字符串,然后再存到Redis,这样不管是PHP还是Java,都能够对其进行解析了!

String(字符串)

  • string 是 redis 最基本的类型,一个 key 对应一个 value。

    username=张三
    
  • string 类型是二进制安全的。

    redis 的 string 可以包含所有数据。比如png图片或者序列化的对象。
    
  • string 类型的值最大能存储 512MB。

    1. 在实际开发过程,还是要注意大小,如果太大的话,还是会影响性能,尽量不要超过 M 大小!
    
    2. 如果真超过一定的大小的时候,还是建议使用文件来存储会比较合适,毕竟redis并不适合大文件存储!
    

示例

redis 127.0.0.1:6379> SET pangugle "盘古歌技术"
OK
redis 127.0.0.1:6379> GET pangugle
"盘古歌技术"

Hash(哈希)

  • Redis hash 是一个键值(key=>value)对集合。

  • Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

示例

redis 127.0.0.1:6379> DEL pangugle
redis 127.0.0.1:6379> HMSET pangugle field1 "baidu" field2 "alibaba"
"OK"
redis 127.0.0.1:6379> HGET pangugle field1
"baidu"
redis 127.0.0.1:6379> HGET pangugle field2
"alibaba"

注意:

第一行 DEL pangugle, 为什么要删除这个,因为我在上面做了一个

SET pangugle "盘古歌技术"

也就是说库里有一个key为 pangugle, 并且类型为字符串,而此时我们要保存的是 hash,因此要先删除, 不然会报错的,如下所示

(error) WRONGTYPE Operation against a key holding the wrong kind of value

每个 hash 可以存储 232 -1 键值对(40多亿)。当然实际开发过程,如果这么多的话,性能也会折扣, 会采取分布式的来安装部署!

List(列表)

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

实例

redis 127.0.0.1:6379> DEL pangugle
redis 127.0.0.1:6379> lpush pangugle alibaba
(integer) 1
redis 127.0.0.1:6379> lpush pangugle baidu
(integer) 2
redis 127.0.0.1:6379> lpush pangugle qq
(integer) 3
redis 127.0.0.1:6379> lrange pangugle 0 10
1) "qq"
2) "baidu"
3) "alibaba"
redis 127.0.0.1:6379>

说明:

lrange pangugle 0 10

此命令表示类似数据库分页提取数据

Set(集合)

  • Redis 的 Set 是 string 类型的无序集合。

  • 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

sadd 命令

添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经在集合中返回 0。

语法:

    sadd key member

实例

redis 127.0.0.1:6379> DEL pangugle
redis 127.0.0.1:6379> sadd pangugle alibaba
(integer) 1
redis 127.0.0.1:6379> sadd pangugle qq
(integer) 1
redis 127.0.0.1:6379> sadd pangugle baidu
(integer) 1
redis 127.0.0.1:6379> sadd pangugle jd
(integer) 0
redis 127.0.0.1:6379> smembers pangugle

1) "baidu"
2) "alibaba"
3) "qq"

注意:

Set(集合)内是具体有唯一性,因此我们执行

sadd pangugle jd

返回 0 表示没有插入成功,也证明它的唯一性

zset(sorted set:有序集合)

  • Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

  • 不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

  • zset的成员是唯一的,但分数(score)却可以重复。

zadd 命令

添加元素到集合,元素在集合中存在则更新对应score

语法:

    zadd key score member

实例

redis 127.0.0.1:6379> DEL pangugle
redis 127.0.0.1:6379> zadd pangugle 0 qq
(integer) 1
redis 127.0.0.1:6379> zadd pangugle 0 baidu
(integer) 1
redis 127.0.0.1:6379> zadd pangugle 0 alibaba
(integer) 1
redis 127.0.0.1:6379> zadd pangugle 0 jd
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE pangugle 0 100
1) "alibaba"
2) "baidu"
3) "qq"

注意:

唯一性