Redis 数据类型

小柒博客
小柒博客
小柒博客
379
文章
108
评论
2020-05-1216:35:55 评论 13.7K 2213字阅读7分22秒

Redis 数据类型

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

String(字符串)

string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个 value。

string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象。

string类型是Redis最基本的数据类型,string类型的值最大能存储512MB。

实例

[root@localhost ~]# redis-cli

127.0.0.1:6379> set test 123

OK

127.0.0.1:6379> get test

"123"

在以上实例中我们使用了Redis的SET和GET命令。键为test,对应的值为123。

注意:一个键最大能存储512MB。

Hash(哈希)

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

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

实例

DEL test用于删除前面测试用过的 key,不然会报错:(error) WRONGTYPE Operation against a key holding the wrong kind of value

[root@localhost ~]# redis-cli

127.0.0.1:6379> del test

(integer) 1

127.0.0.1:6379> HMSET test field1 "Hello" field2 "World"

OK

127.0.0.1:6379> HGET test field1

"Hello"

127.0.0.1:6379> HGET test field2

"World"

实例中我们使用了Redis HMSET, HGET命令,HMSET设置了两个field=>value对, HGET 获取对应field对应的value。

每个hash可以存储232 -1键值对(40多亿)。

List(列表)

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

实例

[root@localhost ~]# redis-cli

127.0.0.1:6379> DEL test

(integer) 1

127.0.0.1:6379> lpush test redis

(integer) 1

127.0.0.1:6379> lpush test mongodb

(integer) 2

127.0.0.1:6379> lpush test rabbitmq

(integer) 3

127.0.0.1:6379> lrange test 0 10

1) "rabbitmq"

2) "mongodb"

3) "redis"

127.0.0.1:6379>

列表最多可存储232 -1元素(4294967295, 每个列表可存储40多亿)。

Set(集合)

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

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

sadd 命令

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

sadd key member

实例

[root@localhost ~]# redis-cli

127.0.0.1:6379> del test

(integer) 1

127.0.0.1:6379> sadd test redis

(integer) 1

127.0.0.1:6379> sadd test mongodb

(integer) 1

127.0.0.1:6379> sadd test rabbitmq

(integer) 1

127.0.0.1:6379> sadd test rabbitmq

(integer) 0

127.0.0.1:6379> smembers test

1) "rabbitmq"

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

实例

[root@localhost ~]# redis-cli

127.0.0.1:6379> DEL test

(integer) 1

127.0.0.1:6379> zadd test 0 redis

(integer) 1

127.0.0.1:6379> zadd test 0 mongodb

(integer) 1

127.0.0.1:6379> zadd test 0 rabitmq

(integer) 1

127.0.0.1:6379> zadd test 0 rabitmq

(integer) 0

127.0.0.1:6379> ZRANGEBYSCORE test 0 1000

1) "mongodb"

2) "rabitmq"

3) "redis"

各个数据类型应用场景:

Redis 数据类型

继续阅读
若文章图片、下载链接等信息出错,请在评论区留言反馈,博主将第一时间更新!如果喜欢本站,请打赏支持本站,谢谢!
  • 微信号
  • 微信扫一扫加我!
  • weinxin
  • 微信公众号
  • 微信扫一扫关注我!
  • weinxin
Redis最后更新:2020-5-25
小柒博客
  • 本文由 发表于 2020-05-1216:35:55
  • 除非特殊声明,本站文章均为原创,转载请务必保留本文链接
Docker 安装 Redis Docker

Docker 安装 Redis

Docker 安装 Redis Redis 简介 Redis 是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value的NoSQL数据库,并提供多种语言...
Redis 分区 Redis

Redis 分区

Redis 分区 分区是分割数据到多个Redis实例的处理过程,因此每个实例只保存key的一个子集。 分区的优势 通过利用多台计算机内存的和值,允许我们构造更大的数据库。 通过多核和多台计...
Redis 管道技术 Redis

Redis 管道技术

Redis 管道技术 Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。这意味着通常情况下一个请求会遵循以下步骤: 客户端向服务端发送一个查询请求,并监听Socke...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: