服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Redis - 浅谈redis五大数据结构和使用场景

浅谈redis五大数据结构和使用场景

2021-08-01 16:29负债程序猿 Redis

这篇文章主要介绍了浅谈redis五大数据结构和使用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

老规矩,先抛结论后验证

浅谈redis五大数据结构和使用场景

string:有点像java的hashmap,存的时候什么key,取的时候也什么key,常用于做缓存,保存用户信息、查询列表等;
hash:这个有点像hashmap的value又套了个hashmap,下文有举例,一看就明白了;
list:有序列表,类似java的linkedlist,可以在左边右边插入数据;
set:去重集合,类似java的hashset,可用于求交集,比如共同好友;
zset:带权重的set集合,可用于做排行榜;

为了方便理解,我们基于这个dog类来做测试,有手就能学会的那种

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//dog类,属性不重要,随便写的
public class dog {
    private string name;
    private string like;
}
================分割线================
//new三只小狗
dog dog1 = new dog("蔡徐鸡", "唱跳");
dog dog2 = new dog("蔡徐公鸡", "rap");
dog dog3 = new dog("蔡徐老母鸡", "篮球");
 
================分割线================
//我们用jedis来操作redis
jedis jedis = new jedis();

1、string:

说明:有点像java的hashmap,存的时候什么key,取的时候也什么key,常用于做缓存,保存用户信息、查询列表等;
操作:set方法,第一个参数是key,第二个参数是value;

浅谈redis五大数据结构和使用场景

key可以随便设置,方便后面对比,我们这里设置key为“string”,value就是dog

?
1
2
3
4
//set
jedis.set("string",dog1.tostring());
//get
jedis.get("string");

看下它在redis中长什么样 (左边很多db,这个不用管,看db0就行)

浅谈redis五大数据结构和使用场景

如果有多个相同的key,前面的会被覆盖掉

?
1
2
3
jedis.set("string",dog1.tostring());
jedis.set("string",dog2.tostring());
jedis.set("string",dog3.tostring());

浅谈redis五大数据结构和使用场景

2、hash

说明:hashmap的value又套了个hashmap;
操作:hset方法,第一个参数是key,第二个参数是field,第三个参数是value

浅谈redis五大数据结构和使用场景
我还没想到怎么比较好的解释这个field,说多了怕误导你们,反正这个就像你new了个hashmap,然后这个hashmap的value又是个hashmap,然后你真正的数据是存在第二个hashmap里面的

?
1
2
3
4
5
6
//类似redis的key
hashmap<object, object> key = new hashmap<>();
key.put("key",dog1);
//类似redis的field,这才是redis的hash类型真正存放数据的
hashmap<object, object> field = new hashmap<>();
key.put("field",field);

还没懂的话就往下面看,别纠结上面那个举例,我也不知道那样说合理不合理

?
1
2
3
jedis.hset("hash", "field1", dog1.tostring());
jedis.hset("hash", "field2", dog2.tostring());
jedis.hset("hash", "field3", dog3.tostring());

看下在redis中长什么样

浅谈redis五大数据结构和使用场景

再看下hash类型在jedis中的方法应该就懂了

浅谈redis五大数据结构和使用场景

hget会让你输入两个参数,第一个是key,第二个是field,这个方法直接返回的是dog对象;
而hgetall只需要输入一个参数,然后返回一个map给你,这个map里面装的全是狗,懂了吧,如果你要获取具体的dog对象,你还的输入一个key,这个key就是那个field;

?
1
2
3
4
5
6
7
8
9
10
11
map<string, string> dogmap= jedis.hgetall("hash");
system.out.println(dogmap);
//下面是打印出来的map
{field1=dog(name=蔡徐鸡, like=唱跳),
 field3=dog(name=蔡徐老母鸡, like=篮球),
 field2=dog(name=蔡徐公鸡, like=rap)}
-----------------------------分割线-------------------------------------
string dog= jedis.hget("hash", "field1");
system.out.println(dog);
//下面是打印出来的dog
dog(name=蔡徐鸡, like=唱跳)

list

说明:有序列表,类似java的linkedlist,可以在左边右边插入数据;
操作:左插入lpush、右插入rpush

我们先插入一条蔡徐鸡

?
1
jedis.lpush("list",dog1.tostring());

浅谈redis五大数据结构和使用场景

然后在蔡徐鸡的左右两边各插一条数据,

?
1
2
jedis.rpush("list",dog2.tostring());//蔡徐公鸡
jedis.lpush("list",dog3.tostring());//蔡徐老母鸡

仔细看下面的顺序

浅谈redis五大数据结构和使用场景

set

说明:去重集合,类似java的set,可用于求交集,比如共同好友;
操作:放入元素sadd,求set的交集sinterstore,sinterstore方法可以有多个参数,因为这个方法会在redis生成一个set,用来存放交集,所以第一个参数是新生成set的名字,后面的参数全都是指定哪些set加入求交集方法

我们先设置两个set,第一个set存放dog1和dog2,第二个set存放dog2和dog3

?
1
2
jedis.sadd("set1",dog1.tostring(),dog2.tostring());
jedis.sadd("set2",dog2.tostring(),dog3.tostring());

浅谈redis五大数据结构和使用场景
浅谈redis五大数据结构和使用场景

我们再往set1里面放个dog1试试

?
1
jedis.sadd("set1",dog1.tostring());

再看看redis的set1里面有几个dog1,既然是set,肯定不允许放入重复数据,所以应该跟上面一样

浅谈redis五大数据结构和使用场景

我们再来看看如何获取set的交集

目前set1里面有蔡徐鸡和蔡徐公鸡,set2里面有蔡徐公鸡和蔡徐老母鸡,那交集就是蔡徐公鸡,来看看是不是

?
1
2
3
//这个方法会在redis生成一个set,用来存放交集
//第一个参数是指定新生成set的名字,后面的参数全都是指定哪些set加入求交集方法
jedis.sinterstore("set","set1","set2");

来看下reids中有没有生成一个叫set的key
浅谈redis五大数据结构和使用场景

可以看到redis生成了一个名叫set的key,并且它的值是set1和set2的交集,大名鼎鼎的蔡徐公鸡~~

zset

说明:带权重的set集合,可用于做排行榜;
操作:添加元素zadd,需要指定元素的权重

?
1
2
3
jedis.zadd("zset", 100, dog1.tostring());//权重为100的dog1
jedis.zadd("zset", 200, dog2.tostring());//权重为200的dog2
jedis.zadd("zset", 300, dog3.tostring());//权重为300的dog3

看看redis中的zset是否按照权重排列

浅谈redis五大数据结构和使用场景

of course!!

说明:以上操作redis的方法仅作为理解redis数据类型举例,实际上每个数据类型都还有很多很多其它方法,具体的本文不展开叙述,其次,我们生产中使用redis时,一定要记得给key设置过期时间,除开一些需要对key做持久化的场景,因为redis是运行在内存中的,如果所有key都持久存在于内存,你服务器顶不住的鸭!!!

到此这篇关于浅谈redis五大数据结构和使用场景的文章就介绍到这了,更多相关redis 数据结构和使用场景内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_33709582/article/details/113516374

延伸 · 阅读

精彩推荐
  • Redis在ssm项目中使用redis缓存查询数据的方法

    在ssm项目中使用redis缓存查询数据的方法

    本文主要简单的使用Java代码进行redis缓存,即在查询的时候先在service层从redis缓存中获取数据。如果大家对在ssm项目中使用redis缓存查询数据的相关知识感...

    caychen8962019-11-12
  • RedisRedis存取序列化与反序列化性能问题详解

    Redis存取序列化与反序列化性能问题详解

    这篇文章主要给大家介绍了关于Redis存取序列化与反序列化性能问题的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    这名字已经存在9742021-02-24
  • RedisRedis数据结构之链表与字典的使用

    Redis数据结构之链表与字典的使用

    这篇文章主要介绍了Redis数据结构之链表与字典的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    白泽来了4052021-08-03
  • Redis聊一聊Redis与MySQL双写一致性如何保证

    聊一聊Redis与MySQL双写一致性如何保证

    一致性就是数据保持一致,在分布式系统中,可以理解为多个节点中数据的值是一致的。本文给大家分享Redis与MySQL双写一致性该如何保证,感兴趣的朋友一...

    mind_programmonkey6432021-08-12
  • Redis就这?Redis持久化策略——AOF

    就这?Redis持久化策略——AOF

    今天为大家介绍Redis的另一种持久化策略——AOF。注意:AOF文件只会记录Redis的写操作命令,因为读命令对数据的恢复没有任何意义...

    头发茂密的刘叔4052021-12-14
  • RedisRedis分布式锁升级版RedLock及SpringBoot实现方法

    Redis分布式锁升级版RedLock及SpringBoot实现方法

    这篇文章主要介绍了Redis分布式锁升级版RedLock及SpringBoot实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以...

    等不到的口琴7802021-07-25
  • Redisredis启动,停止,及端口占用处理方法

    redis启动,停止,及端口占用处理方法

    今天小编就为大家分享一篇redis启动,停止,及端口占用处理方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧 ...

    澄海单挑狂5152019-11-14
  • RedisLinux Redis 的安装步骤详解

    Linux Redis 的安装步骤详解

    这篇文章主要介绍了 Linux Redis 的安装步骤详解的相关资料,希望大家通过本文能掌握如何安装Redis,需要的朋友可以参考下 ...

    carl-zhao3822019-11-08