redis种类型对应java类型_Redis系列~数据类型(三)
Redis⽀持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sortedset:有序集合)。String(字符串)string是redis最基本的类型,你可以理解成与Memcached⼀模⼀样的类型,⼀个key对应⼀个value。string类型是⼆进制安全的。意思是redis的string可以包含任何数据。⽐如j数据库
Redis⽀持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
String(字符串)
string是redis最基本的类型,你可以理解成与Memcached⼀模⼀样的类型,⼀个key对应⼀个value。
string类型是⼆进制安全的。意思是redis的string可以包含任何数据。⽐如jpg图⽚或者序列化的对象 。
string类型是Redis最基本的数据类型,⼀个键最⼤能存储512MB。
实例
redis127.0.0.1:6379>SET name"runoob"OK
redis127.0.0.1:6379>GET name"runoob"
在以上实例中我们使⽤了 Redis 的 SET 和 GET 命令。键为 name,对应的值为 runoob。
注意:⼀个键最⼤能存储512MB。
Hash(哈希)
redis支持的五种数据类型Redis hash 是⼀个键值对集合。
Redis hash是⼀个string类型的field和value的映射表,hash特别适合⽤于存储对象。
实例
127.0.0.1:6379>HMSET user:1username runoob password runoob points200OK127.0.0.1:6379>HGETALL
user:11)"username"2)"runoob"3)"password"4)"runoob"5)"points"6)"200"
以上实例中 hash 数据类型存储了包含⽤户脚本信息的⽤户对象。 实例中我们使⽤了 Redis HMSET, HGETALL 命令,user:1 为键值。
每个 hash 可以存储 2
32
-1 键值对(40多亿)。
List(列表)
Redis 列表是简单的字符串列表,按照插⼊顺序排序。你可以添加⼀个元素到列表的头部(左边)或者尾部(右边)。
实例
redis127.0.0.1:6379>lpush runoob redis(integer)1redis127.0.0.1:6379>lpush runoob
mongodb(integer)2redis127.0.0.1:6379>lpush runoob rabitmq(integer)3redis127.0.0.1:6379>lrange
runoob0101)"rabitmq"2)"mongodb"3)"redis"redis127.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
实例
redis127.0.0.1:6379>sadd runoob redis(integer)1redis127.0.0.1:6379>sadd runoob
mongodb(integer)1redis127.0.0.1:6379>sadd runoob rabitmq(integer)1redis127.0.0.1:6379>sadd runoob
rabitmq(integer)0redis127.0.0.1:6379>smembers runoob1)"rabitmq"2)"mongodb"3)"redis"
注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯⼀性,第⼆次插⼊的元素将被忽略。
集合中最⼤的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。
zset(sorted set:有序集合)
Redis zset 和 set ⼀样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联⼀个double类型的分数。redis正是通过分数来为集合中的成员进⾏从⼩到⼤的排序。
zset的成员是唯⼀的,但分数(score)却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
zadd key score member
实例
redis127.0.0.1:6379>zadd runoob0redis(integer)1redis127.0.0.1:6379>zadd
runoob0mongodb(integer)1redis127.0.0.1:6379>zadd runoob0rabitmq(integer)1redis127.0.0.1:6379>zadd
runoob0rabitmq(integer)0redis127.0.0.1:6379>ZRANGEBYSCORE runoob010001)"redis"2)"mongodb"3)"rabitmq"
本⽂由来源 hemin1003,由 system_mush 整理编辑,其版权均为 hemin1003 所有,⽂章内容系作者个⼈观点,不代表 Java架构师必看 对观点赞同或⽀持。如需转载,请注明⽂章来源。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。