Redis 数据类型
Redis 数据类型
Redis 支持五种数据类型:String(字符串)、hash(哈希)、list(列表)、set(集合)及zset(sorted set:有序集合)。
String(字符串)
- string是Redis最基本的数据类型,你可以理解成与Memcached 一模一样的类型。一个key对应一个value。
- string 类型是二进制安全的。意思是Redis 的string 可以包含任何数据。比如jpg图片或者序列化的对象。
- string 类型是Redis 最基本的数据类型,string 类型的值最大能存储512MB。
实例:
redis 127.0.0.1:6379> SET name "runoob" OK redis 127.0.0.1:6379> GET name "runoob"
在以上实例中我们使用了Redis 的SET和GET命令。键为name,对应的值为runoob。
**注意:**一个键最大能存储512MB。
Hash(哈希)
Redis hash 是一个键值(key=>value)对集合。
Redis hash是一个string 类型的field和value 的映射表,hash特别适合用于存储对象。
实例:
DEL runoob用于删除前面测试用过的key,不然会报错:(error) WRONGTYPE Operation against a key holding the wrong kind of value
redis 127.0.0.1:6379> DEL runoob redis 127.0.0.1:6379> HMSET myhash field1 "Hello" field2 "World" "OK" redis 127.0.0.1:6379> HGET myhash field1 "Hello" redis 127.0.0.1:6379> HGET myhash field2 "World"
实例中我们使用了Redis HMMSET, HGET命令,HMSET设置了两
field=>value对,HGET获取对应field对应的value。
每个hash可以存储 232-1键值对(40多亿)。
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
实例:
redis 127.0.0.1:6379> DEL runoob redis 127.0.0.1:6379> lpush runoob redis (integer) 1 redis 127.0.0.1:6379> lpush runoob mongodb (integer) 2 redis 127.0.0.1:6379> lpush runoob rabitmq (integer) 3 redis 127.0.0.1:6379> lrange runoob 0 10 1) "rabitmq" 2) "mongodb" 3) "redis" redis 127.0.0.1:6379>
列表最多可存储232-1元素(4294967295,每个列表可存储40多亿)。
Set(集合)
Redis 的Set 是string类型的无序集合。
集合是通过哈希表实现的,所以添加、删除、查找的复杂度都是O(1)。
sadd命令
添加一个string元素到key 对应的set集合中,成功返回1,如果元素已经在集合中返回0,如果key 对的set不存在则返回错误。
sadd key member
实例:
redis 127.0.0.1:6379> DEL runoob redis 127.0.0.1:6379> sadd runoob redis (integer) 1 redis 127.0.0.1:6379> sadd runoob mongodb (integer) 1 redis 127.0.0.1:6379> sadd runoob rabitmq (integer) 1 redis 127.0.0.1:6379> sadd runoob rabitmq (integer) 0 redis 127.0.0.1:6379> smembers runoob 1) "redis" 2) "rabitmq" 3) "mongodb"
注意:以上实例中rabiting 添加了两次,但根绝集合内元素的唯一性,第二次插入的元素将被忽略。
集合中最大的成员数为232-1(4294967295,每个列表可存储40多亿)。
zset(sorted set:有序集合)
Redis zset 和set一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。Redis正式通过分数来为集合中的成员进行从小到大的排序。
zset 的长远是卫衣的,但是分数(score)却可以重复。
zadd命令
添加元素到集合,元素在集合中存在则更新对应score。
zadd key score member
实例:
redis 127.0.0.1:6379> DEL runoob redis 127.0.0.1:6379> zadd runoob 0 redis (integer) 1 redis 127.0.0.1:6379> zadd runoob 0 mongodb (integer) 1 redis 127.0.0.1:6379> zadd runoob 0 rabitmq (integer) 1 redis 127.0.0.1:6379> zadd runoob 0 rabitmq (integer) 0 redis 127.0.0.1:6379> > ZRANGEBYSCORE runoob 0 1000 1) "mongodb" 2) "rabitmq" 3) "redis"
各种类型的应用场景
类型 | 简介 | 特性 | 场景 |
---|---|---|---|
String(字符串) | 二进制安全 | 可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512MB | ---- |
Hash(字典) | 键值对集合,即编程语言中的Map集合 | 适合存储对象,并且可以像数据库中updata一个属性一样只修改某一项属性值(Memcached中需要去除整个字符串反序列化成对象修改完再序列化存回去) | 存储、读取、修改用户属性 |
List(列表) | 链表(双向链表) | 增删快,提供了操作某一段元素的API | 1,最新消息排行等功能(比如朋友圈的时间线)2.消息队列 |
Set(集合) | 哈希集实现,元素不重复 | 1.添加、删除、查找的复杂度都是O(1)。2.为集合提供了求交集、并集、差集等操作 | 1.共同好友2.利用唯一性,统计访问网站的所有独立IP。3.好友推荐时,跟进tag求交集。大于某个阈值就可以推荐 |
Sorted Set(有序集合) | 将Set中的元素增加一个权值参数score,元素按照score有序排列 | 数据插入集合时,已经进行天然排序 | 1.排序榜 2.带权重的消息队列 |
**注意:**Redis支持多个数据库,并且每个数据库的数据是隔离的不能共享,并且基于单机才有,如果是集群就没有数据库的概念。
Redis 是一个字典结构的存储服务器,而实际上一个Redis 实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。这与我们熟知的在一个关系数据可实例中可以创建多个数据库类似,所以可以将其中的每个字典都理解长一个独立的数据库。
- NoSQL之Redis对set(集合)数据类型的操作之一
- Redis常用数据类型介绍、使用场景及其操作命令
- NoSQL之Redis(二)---Java操作Redis存储自定义类型数据
- redis_2_key_五大数据类型常用命令
- redis爬坑记(二) redis的数据类型
- redis 五种数据类型的使用场景
- Redis基础之数据类型(Hash哈希表)
- redis 五种数据类型的使用场景
- redis的常见数据类型
- (10-6)redis -set 数据类型
- redis学习--基础5 数据类型hash
- Redis 数据类型,api,应用场景
- Redis源码解析(三):redis之数据类型String
- 「redis存储篇」string数据类型的操作
- Redis数据类型与基本操作
- Redis学习笔记-List数据类型
- redis五种基本数据类型
- redis数据类型总结
- Redis 的数据类型介绍与命令操作
- Redis数据类型