Redis常用的数据结构

非关系型数据库,NoSQL。一种以键值对形式存储数据的系统。

通用命令:对任何数据结构都适用。

KEYS:查看符合模板的所有Key,模板一般为正则表达式(通配符),不建议在生产环境设备下使用:因为当数据量非常大的时候,加上又是单线程,会阻塞

DEL:删除一个或者多个key

EXISTS:判断key是否存在

EXPIRE:给key设置有效期

TTL:查看一个key的有效时期,-1为永久存在,-2为不存在

HELP[COMMAND]:具体查看一个命令的使用

String类型

底层都是用字节数组形式存储

SET 对于一个已经存在的key,则会修改value值

  • set:添加或者修改已经存在的一个String类型的键值对

  • get:根据key获取String类型的value

  • increment:让一个整型的key自增1

  • decrement:等同于increment 负数

setIfAbsent:参数为key,value,【过期时间】,【时间的单位,默认为秒】

Hash类型

也叫散列,其value是一个无序字典,类似于Java中的HashMap结构

String结构是将对象序列化为JSON字符串后存储,当需要修改对象某个字段时很不方便

Hash结构可以将对象中的每个字段独立存储,可以针对单个字段做CRUD

常用命令:

get:根据对应的key以及value中的字段获取对应的值

put:添加或者修改hash类型key的field的值(一次操作一个字段【一行】)

putAll:批量插入多个hash类型key,value为Map(一次操作一个对象(可能是多行))

项目中,将获取到的UserDTO对象转成Hash,插入到redis中

entries:通过key获取map集合

List类型

与Java中的LinkedList类似,可以看做是一个双向链表结构。既可以支持正向检索和也可以支持反向检索。

特点:有序,允许重复,插入速度快,但是查询速度一般。

场景:朋友圈点赞列表,评论列表等。【用来存取根据有先后顺序】

rightPushAll:向列表key右侧插入一个list集合

leftPop:将列表key左侧的元素移除,没有则返回nil。【指定个数】【等待时间】【时间的单位】如果指定了时间,在没有元素时等待指定时间,而不是直接返回nil

rightPush:向列表key右侧插入一个元素

range:取出下标从start到end的全部元素

Set类型

与Java中的HashSet类似,可以看做是一个value为null的HashMap,具备hashSet的特征。

特点:无需,元素不可重复,查询快,支持交集、并集、差集。

add:向set类型的key插入一个或多个元素,返回插入的个数

isMember:判断元素...(可以一次判断多个)是否存在key集合中,返回布尔值

difference:求key1与key2的差集

intersect:求key1与key2的交集

pop:取出指定元素【个数】

randomMember:

size:求集合大小,返回Long类型

union:求key1与key2的并集

ZSet类型

Redis的SortedSet是一个可排序的set集合,与Java中的TreeSet有些类似,但底层数据结构却差别很大。SortedSet中的每一个元素都带有一个score属性,可以基于score属性对元素排序,底层的实现是一个跳表(SkipList)加 hash表。同样也支持交集、并集、差集。

特点:可排序,元素不可重复,查询速度快

场景:常用来做排行榜这样的功能(可排序)

所有排序如果不带Reverse 都默认为升序,带了Reverse均为降序。

range:同List类型,取出下标从start到end的全部元素(经常和size一起用)

reverserRangeByScoreWithScores:倒序取出score属性从min到max的全部元素

返回值为

count:计数,返回值为Long

  • 27
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Redis常用数据结构有六种,分别是简单动态字符串(SDS)、链表、字典、跳跃表、整数集合和压缩列表。这些数据结构被用来构建Redis的对象系统,包括字符串对象、列表对象、哈希对象、集合对象和有序集合对象。每种对象都有多种不同的数据结构实现,以适应不同的应用场景。字符串类型是Redis最基础的数据结构,它的值可以是简单的字符串、复杂的字符串(如JSON、XML)、数字(整数、浮点数)甚至二进制数据(如图片、音频、视频),但值的大小不能超过512MB。Redis中的字符串是动态字符串,可以通过预分配冗余空间的方式减少内存分配的频率。字符串的长度不超过1MB时,扩容时会加倍现有的空间;而超过1MB时,每次扩容只会增加1MB的空间。需要注意的是,Redis规定字符串的长度不能超过512MB。123 #### 引用[.reference_title] - *1* [Redis常见数据结构](https://blog.csdn.net/weixin_42348609/article/details/102996982)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* [Redis-常用数据结构](https://blog.csdn.net/Huangjiazhen711/article/details/127567141)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *3* [Redis的五种基础数据结构](https://blog.csdn.net/yuyuanlai/article/details/106745757)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值