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"
注意:
唯一性