redis 的数据类型主要有五种
字符串(String)
哈希表(Hash)
列表(List)
集合(Set )
有序集合(Sorted Set)
1. 字符串
一个 key 对应一个 value
该数据类型是二进制的,很安全,可以保存任何数据,设置保存图片和数据对象
一个key 最大可以保存512M大小的value
实例:
结构如下:
一个键值对集合
一个 string 类型的 field 和 value 的映射表,Hash特别适合用于存储对象
每个 hash 可以存储 232 -1 键值对(40多亿)
实例:
数据结构如下:
哈希类型有点类似一个对象表,该对象表中存该对象的属性(field),及该属性对应的值(value)
Redis 列表是简单的字符串列表,按照插入顺序排序,你可以添加一个元素到列表的头部(左边)或者尾部(右边)
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
实例:
列表结构如下
Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。
集合中的值是不重复的,填加集合中已存在的值,是加不进去的
实例:
集合结构如下:
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员,添加已存在的成员,是加不进去的,操作会失败
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
实例:
结构如下:
关于以上5种数据类型总结一下:
集合和有序集合相同点:不允许出现重复的元素;不同点:(1)有序集合,只要成员名不重复就可以,成员可以有相同的分数;(2)有序集合会根据score的值排序,而集合中元素在插入后在集合中出现的位置的不确定的。
列表和集合比较:从结构上来说,集合插入元素后,元素在集合中所在的位置与插入的顺序无关,而列表lpush的元素出现在列表顶部,rpush的元素出现在列表的底部,列表可以重复插入的已存在的元素,而集合却会失败