Redis 共有 5 种基本数据类型:String(字符串)、List(列表)、Set(集合)、Hash(散列)、Zset(有序集合)。
这 5 种数据类型是直接提供给用户使用的,是数据的保存形式,其底层实现主要依赖这 8 种数据结构:简单动态字符串(SDS)、LinkedList(双向链表)、Dict(哈希表/字典)、SkipList(跳跃表)、Intset(整数集合)、ZipList(压缩列表)、QuickList(快速列表)。
Redis 是一个开源的内存数据结构存储系统,它支持多种数据类型,包括字符串、哈希表、列表、集合和有序集合。这些数据类型使得 Redis 成为一个非常灵活和强大的数据存储系统,可以用于各种不同的应用场景,如缓存、消息队列、排行榜等。
Redis 中的字符串类型是一种二进制安全的类型,可以存储任何二进制数据,包括图片、音频、视频等文件。字符串类型还支持一些常用的操作,如获取字符串长度、追加字符串、截取字符串等。
此外,Redis 还支持对字符串类型进行模式匹配,可以使用类似于正则表达式的模式进行匹配。这种模式匹配功能可以用于实现一些通用的搜索和过滤功能。
Redis 中的哈希表类型是一种键值对的存储方式,可以用于存储对象的属性。哈希表中的每个键值对都是一个独立的字段,字段的值可以是任意的 Redis 数据类型,包括字符串、哈希表、列表、集合和有序集合等。
哈希表类型非常适合用于存储对象信息,可以通过哈希表的键来访问对象的属性,而不需要将整个对象都加载到内存中。此外,Redis 还支持对哈希表进行原子性的操作,可以保证多个客户端对同一个哈希表进行并发操作时的数据一致性。
Redis 中的列表类型是一种有序的字符串集合,可以用于存储多个字符串,并按顺序排列。列表类型的元素可以是任意的 Redis 数据类型,包括字符串、哈希表、列表、集合和有序集合等。
Redis 支持对列表类型进行各种操作,如向列表中追加元素、弹出列表中的第一个元素、获取列表中的元素等。此外,Redis 还支持对列表进行原子性的操作,可以保证多个客户端对同一个列表进行并发操作时的数据一致性。
Redis 中的集合类型是一种无序的字符串集合,可以用于存储多个唯一的字符串。集合类型的元素只能是字符串类型,而且必须是唯一的。
Redis 支持对集合类型进行各种操作,如向集合中添加元素、从集合中移除元素、获取集合的交集、并集等。此外,Redis 还支持对集合进行原子性的操作,可以保证多个客户端对同一个集合进行并发操作时的数据一致性。
Redis 中的有序集合类型是一种无序的字符串集合,可以用于存储多个唯一的字符串,并按照一定的顺序排列。每个元素都有一个相关的分数,根据这个分数进行排序。
Redis 支持对有序集合类型进行各种操作,如向有序集合中添加元素、获取有序集合中的元素、获取有序集合的交集、并集等。此外,Redis 还支持对有序集合进行原子性的操作,可以保证多个客户端对同一个有序集合进行并发操作时的数据一致性。
除了以上五种基本数据类型,Redis 还支持其他一些高级数据类型,如位图(Bitmap)、hyperloglogs(HyperLogLog)和地理空间数据类型(Geo)。
Redis 的位图类型是一种基于位运算的数据结构,可以用于存储大量的二进制数据,并且支持对二进制数据进行位运算操作。位图类型非常适合用于存储大量的布尔值,因为每个比特位都可以表示一个布尔值。
Redis 的 hyperloglogs 类型是一种概率统计数据结构,可以用于估计集合的基数(cardinality)。hyperloglogs 类型使用了 loglog 算法来估计集合的基数,相对于传统的计数算法,它具有更高的精度和更好的性能。
Redis 的 geo 数据类型是一种用于存储地理位置信息的类型,可以用于实现地理位置的搜索、距离计算等功能。geo 数据类型支持存储经纬度信息,并且支持对地理位置进行各种操作,如计算两个地理位置之间的距离、搜索位于某个圆形区域内的地理位置等。
除了以上数据类型之外,Redis 还支持一些其他的特性,如事务(Transaction)、发布订阅(Pub/Sub)、Lua 脚本等。这些特性使得 Redis 成为一个非常灵活和强大的数据存储系统,可以用于各种不同的应用场景。