文章目录
- Redis键值概述
- 一、Redis数据类型概述
- 常用数据类型
- String
- List
- Hash
- Set
- Zset
- 扩展数据类型
- BitMap
- HyperLogLog
- GEO
- BitField
- Stream
- 二、Redis键(key)操作
- 常用操作及示例
- keys *
- exists key
- type key
- del key
- unlink key
- ttl key
- expire key seconds
- move key dbindex
- select dbindex
- dbsize
- flushdb
- flushall
- 常用操作汇总
- 总结
Redis键值概述
一、Redis数据类型概述
首先要强调一点:Redis是key value
类型的数据库,Redis所说的数据类型都是key value
中的value
的数据结构, 而key
都是字符串。
常用数据类型
Redis中有经常使用的有五大数据类型,分别是——String(字符串),Hash(哈希),List(列表),Set(集合)、Zset(有序集合)。
String
String是redis最基本的类型,一个key对应一个value。
String类型是二进制安全的,意思是Redis的String可以包含任何数据,比如jpg图片或者序列化的对象 。
String类型是Redis最基本的数据类型,一个Redis中字符串value最多可以是512M。
List
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
List中最多可以最多可以包含
Hash
Redis Hash 是一个 String 类型的 field(字段) 和 value(值) 的映射表,Hash 特别适合用于存储对象。
Redis 中每个 Hash 可以存储
Set
Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中Set集合是通过哈希表实现的(这里先这样认为),所以添加,删除,查找的复杂度都是 O(1)。
集合中最大的成员数为 (4294967295, 每个集合可存储40多亿个成员)。
Zset
Redis Zset 和 Set 一样也是String类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数,redis正是通过分数来为集合中的成员进行从小到大的排序。
Zset的成员是唯一的,但分数(score)却可以重复。
Zset集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 。
扩展数据类型
随着 Redis 版本的更新,后面又支持了五种数据类型: BitMap(2.2 版新增)、HyperLogLog(2.8.9 版本新增)、GEO(3.2 版新增)、BitField(3.2 版新增)、Stream(5.0 版新增)。
BitMap
Redis中的BitMap不是一个独立的数据类型,而是基于String类型实现的一种特殊的数据结构。BitMap主要用于存储大量二进制位(0或1)的数据,这些位可以代表不同的状态或标志。
BitMap,即位图,是一串连续的二进制数组(0和1),可以通过偏移量(offset)定位元素。BitMap通过最小的单位bit来进行 0|1 的设置,表示某个元素的值或者状态,时间复杂度为O (1)。由于bit是计算机中最小的单位,使用它进行储存将非常节省空间,特别适合一些数据量大且使用二值统计的场景。
示例如下图:
Redis的BitMap实际上是利用String类型的最大容量(512 MB)存储一个连续的二进制序列,其中每个字节的8位可以分别代表8个独立的状态。这意味着你可以用一个BitMap来跟踪多达数百万甚至数十亿的状态,只要状态总数不超过,即大约。
HyperLogLog
HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定且是很小的。
在 Redis 里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近
但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。
GEO
Redis的GEO类型主要用于存储地理位置信息,并对存储的信息进行操作。GEO实际上是一种有序集合(zset),它的每个元素都包含三个属性:经度(longitude)、纬度(latitude)和位置名称(member)。通过这些属性,我们可以在Redis中存储地理位置的坐标,并对它们进行一些有用的操作。
BitField
Redis的BITFIELD命令可以将一个Redis字符串看作是一个由二进制位组成的数组,并对这个数组中任意偏移进行访问。BITFIELD命令的作用在于它能够将很多小的整数储存到一个长度较大的位图中,又或者将一个非常庞大的键分割为多个较小的键来进行储存,从而非常高效地使用内存,使得Redis能够得到更多不同的应用,特别是在实时分析领域。
说白了就是通过BITFIELD命令我们可以一次性对多个比特位域进行操作。
Stream
Redis Stream 主要用于消息队列(MQ,Message Queue),Redis 本身是有一个 Redis 发布订阅 (pub/sub) 来实现消息队列的功能,但它有个缺点就是消息无法持久化,如果出现网络断开、Redis 宕机等,消息就会被丢弃。
简单来说发布订阅 (pub/sub) 可以分发消息,但无法记录历史消息。
而 Redis Stream 提供了消息的持久化和主备复制功能,可以让任何客户端访问任何时刻的数据,并且能记住每一个客户端的访问位置,还能保证消息不丢失
二、Redis键(key)操作
常用操作及示例
keys *
查看当前库的所有key
示例如下:
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> keys *
1) "k2"
2) "k1"
exists key
检查key是否存在,存在返回1,不存在返回0
示例如下:
127.0.0.1:6379> keys *
1) "k2"
2) "k1"
127.0.0.1:6379> EXISTS k1
(integer) 1
127.0.0.1:6379> EXISTS k3
(integer) 0
type key
返回key的类型
示例如下:
127.0.0.1:6379> type k1
string
del key
删除一个或多个key
示例如下:
127.0.0.1:6379> keys *
1) "k2"
2) "k1"
127.0.0.1:6379> del k1
(integer) 1
127.0.0.1:6379> keys *
1) "k2"
unlink key
非阻塞删除一个或多个key,并异步释放和key相关的内存;返回1表示删除成功,返回0表示删除失败
示例如下:
127.0.0.1:6379> keys *
1) "k1"
2) "k2"
127.0.0.1:6379> unlink k1
(integer) 1
127.0.0.1:6379> keys *
1) "k2"
ttl key
获取key的剩余过期时间,单位为秒;-1表示永不过期,-2表示已过期
示例如下:
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> ttl k1
(integer) -1
127.0.0.1:6379> expire k1 10 # 设置过期时间为10s
(integer) 1
127.0.0.1:6379> ttl k1
(integer) 5
127.0.0.1:6379> ttl k1
(integer) -2
expire key seconds
设置key的过期时间,单位为秒;返回1表示设置成功,返回0表示设置失败
自Redis 7.0,
expire
支持如下参数:
- NX:只有当key没有设置过期时间,才会执行命令(已经设置过的,不能再设置)
- XX :只有当key有过期时间,才会执行命令设置(没有设置过的,不能设置)
- GT :只有当新的过期时间大于当前过期时间时,才会设置(只会增加过期时间)
- LT :只有当新的过期时间大于当前过期时间时,才会设置(只会减少过期时间)
可选参数这里先不做演示,有兴趣的小伙伴可以自己去尝试。
示例如下:
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> ttl k1
(integer) -1
127.0.0.1:6379> expire k1 10 # 设置过期时间为10s
(integer) 1 # 1表示成功,0表示失败
127.0.0.1:6379> ttl k1
(integer) 5
127.0.0.1:6379> ttl k1
(integer) -2
Redis 的过期时间设置有四种形式:
- EXPIRE 秒——设置指定的过期时间(秒),表示的是时间间隔。
- PEXPIRE 毫秒——设置指定的过期时间,以毫秒为单位,表示的是时间间隔。
- EXPIREAT 时间戳-秒——设置指定的 Key 过期的 Unix 时间,单位为秒,表示的是时间/时刻。
- PEXPIREAT 时间戳-毫秒——设置指定的 Key 到期的 Unix 时间,以毫秒为单位,表示的是时间/时刻。
move key dbindex
将当前数据库的key移动到给定的数据库dbindex(0~15)。
Redis支持多个数据库,每个数据库都是一个独立的键值空间,这意味着同一个Redis实例中的不同数据库可以拥有相同的key。在某些情况下,我们可能需要将一个key从一个数据库移动到另一个数据库。
示例如下:
127.0.0.1:6379> keys *
1) "k1"
2) "k2"
127.0.0.1:6379> move k1 13
(integer) 1
select dbindex
切换到指定的数据库dbindex(0~15),默认为0。
示例如下:
127.0.0.1:6379> select 13
OK
127.0.0.1:6379[13]> keys *
1) "k1"
127.0.0.1:6379[13]> select 0
OK
127.0.0.1:6379> keys *
1) "k2"
dbsize
返回当前数据库的key的总数
示例如下:
127.0.0.1:6379> keys *
1) "k1"
2) "k2"
127.0.0.1:6379> dbsize
(integer) 2
127.0.0.1:6379> select 13
OK
127.0.0.1:6379[13]> keys *
1) "k1"
127.0.0.1:6379[13]> dbsize
(integer) 1
flushdb
删除当前数据库中的所有Key,不会影响其他库
示例如下:
127.0.0.1:6379[13]> keys *
1) "k1"
127.0.0.1:6379[13]> flushdb
OK
127.0.0.1:6379[13]> keys *
(empty array)
127.0.0.1:6379[13]> select 0 # 不影响其他库
OK
127.0.0.1:6379> keys *
1) "k1"
2) "k2"
flushall
删除所有数据库中的所有Key
示例如下:
127.0.0.1:6379[13]> select 0
OK
127.0.0.1:6379> keys *
1) "k1"
2) "k2"
127.0.0.1:6379> select 13
OK
127.0.0.1:6379[13]> keys *
1) "k3"
2) "k4"
127.0.0.1:6379[13]> flushall
OK
127.0.0.1:6379[13]> keys *
(empty array)
127.0.0.1:6379[13]> select 0 # 0和13号数据库中的数据都被清除了
OK
127.0.0.1:6379> keys *
(empty array)
常用操作汇总
命令 | 描述 |
| 查看当前库的所有key |
| 检查key是否存在,存在返回1,不存在返回0 |
| 返回key的类型 |
| 删除一个或多个key |
| 删除一个或多个key,并异步释放和key相关的内存 |
| 获取key的剩余过期时间,单位为秒;-1表示永不过期,-2表示已过期。 |
| 设置key的过期时间,单位为秒 |
| 将当前数据库的key移动到给定的数据库dbindex |
| 切换到指定的数据库dbindex |
| 返回当前数据库的key的总数 |
| 删除当前数据库中的所有Key |
| 删除所有数据库中的所有Key |
这里补充一点,Redis中的操作一般是1
代表操作执行成功,0
代表操作执行失败。
总结
在本文中,我们对Redis的键值存储进行了全面的概述和介绍。首先,我们了解了Redis的五大基本数据类型:String(字符串)、Hash(哈希)、List(列表)、Set(集合)和Zset(有序集合),并探讨了它们各自的特点和用法。随后,我们介绍了五种扩展数据类型:BitMap、HyperLogLog、GEO、BitField和Stream,以及它们在实际应用中的用途和优势。
在键(key)操作方面,我们涵盖了常用的操作,包括查看、检查、删除、移动、切换数据库以及设置过期时间等。这些操作丰富了我们对Redis数据管理的理解,使我们能够更有效地管理和操作Redis中的数据。
通过本文的学习,读者可以更加深入地了解Redis的键值存储特性,为其在实际应用中的使用提供了更多的参考和指导。Redis作为一款高性能的键值存储数据库,在各种场景下都具有广泛的应用前景,希望本文能为读者在Redis的学习和应用上提供一些帮助和启发。
如果讲解有不对之处还请指正,我会尽快修改,多谢大家的包容。
如果大家喜欢这个系列,还请大家多多支持啦😋!