redis常用数据结构及操作方式

key一般是String类型,value的类型是多种多样的

  • 字符串类型: String k-v形式
  • 哈希类型:hash 哈希表的形式
  • 列表类型:list 有序链表,可重复
  • 集合类型:set 无序集合,且不可重复
  • 有序集合类型:sortedset 有序的,可排序的集合,元素不可重复

通用命令:

  • KEYS:查看符合模板的所有的key,比如keys *,查看所有的key;key a*,查看所有以a开头的key;但是不建议在环境设备上使用.
  • DEL:删除一个指定的key,可以设置多个,返回删除的个数,如果删除一个不存在的key,不报错,无影响.
  • EXISTS:判断key是否存在,存在返回1,不存在返回0
  • EXPIRE:给key设置有效期,有效期到期时key会被自动删除;例如EXPIRE name 20 (name之前已存在)
  • TTL:查看一个key的剩余有效期. (-1永久有效,-2无效,且key被删除)

字符串:string

String类型,也就是字符串类型,是redis中最简单的存储类型,key为String,value可以有多种形式:

String:字符串;

int:整数类型,可以做自增,自减的操作;

float:浮点类型,可以做自增,自减操作.

常用方法:

  • SET:添加或者修改已经存在的一个string类型的键值对
  • GET: 根据key获取String类型的value
  • MSET:批量添加多个String类型的键值对
  • MGET:根据多个key获取多个string类型的value
  • INCR:让一个整型的key自增1
  • INCRBY:让一个整型的key自增并指定步长,例如:incrby num 2让num值自增2
  • INCRBYFLOAT:让一个浮点类型的数字自增并指定步长
  • SETNX:添加一个string类型的键值对,前提是这个key不存在,否则不执行
  • SETEX:添加一个5tring类型的键值对,并且指定有效期

哈希类型:hash

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

常用方法:

  • HSET key field value: 添加或者修改hash类型key的field的值
  • HGET key field:获取一个hash类型key的field的值
  • HMSET:批量添加多个hash类型key的field的值
  • HMGET:批量获取多个hash类型key的field的值
  • HGETALL:获取一个hash类型的key中的所有的field和value
  • HKEY:获取一个hash类型的key中的所有的field
  • HVALS:获取一个hash类型的key中的所有的value
  • HINCRBY:让一个hash类型key的字段值自增并指定步长
  • HSETNX:添加一个hash类型的key的field值,前提是这个field不存在,否则不执行

列表类型:list

redis中的list类型与Java中的LinkedList类似,可以看作是一个双向链表,即支持正向检索,也支持反向检索;特征也和LinkedList类似:

有序,元素可重复,插入和删除快,查询速度一般;

常用来存储一个有序数据,如:朋友圈点赞列表,评论列表等.

常用方法:

  • lLPUSH key element...:向列表左侧插入一个或多个元素
  • LPoP key: 移除并返回列表左侧的第一个元素,没有则返回nil
  • RPUSH key element...:向列表右侧插入一个或多个元素
  • RPoP key:移除并返回列表右侧的第一个元素
  • LRANGE key star end: 返回一段角标范围内的所有元素
  • BLPOP和BRPOP:与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回nil,需要设置时间,没有数据会一直阻塞,有数据时会获取到key,value以及时间

集合类型:set

Redis的Set结构与Java中的HashSet类似,可以看作一个value为null的HashMap,因为也是一个hash表,因此具备与HashSet类似的特征:

无序,元素不可重复,查找快,支持交集、并集,差集等功能

常用方法:

  • SADD key member ...:向set中添加一个或多个元素
  • SREM key member...:移除set中的指定元素
  • SCARD key: 返回set中元素的个数
  • SISMEMBER keymember:判断一个元素是否存在于set中
  • SMEMBERS:获取set中的所有元素
  • SINTER key1 key2 ...:key1与key2的交集
  • SDIFF key1 key2 ...:求key1与key2的差集
  • SUNION key1 key2 ..:求key1和key2的并集

有序集合类型:zset

Redis的SortedSet是一个可排序的set集合,与ava中的TreeSet有些类似,但底层数据结构却差别很大。SortedSet中的每一个元素都带有一个score届性,可以基于score届性对元素排序,底层的实现是一个跳表(Skiplist)加 hash表SortedSet具备下列特性:

可排序

元素不重复

速快

因为SortedSet的可排序特性,经常被用来实现排行榜这样的功能。

常用方法:

  • ZADD key score member: 添加一个或多个元素到sorted set,如果已经存在则更新其score值
  • ZREM key member:删除sorted set中的一个指定元素
  • ZSCORE key member: 获取sorted set中的指定元素的score值
  • ZRANK key member: 获取sorted set 中的指定元素的排名
  • ZCARD key: 获取sorted set中的元素个数
  • ZCOUNT key min max: 统计score值在给定范围内的所有元素的个数
  • ZINCRBY keyincrement member: 让sorted set中的指定元素自增,步长为指定的increment值
  • ZRANGE key min max:按照score排序后,获取指定排名范围内的元素
  • ZRANGEBYSCORE key min max: 按照score排序后,获取指定5core范围内的元素
  • ZDIFF、ZINTER、ZUNION: 求差集、交集、并集

注:所有的排名默认都是升序,如果要降序则在命令的Z后面添加REV即可(ZREVRANK)

素材取自:基础篇-17.Redis的Java客户端-Jedis的连接池_哔哩哔哩_bilibili

侵权立删.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值