天天看點

redis五大資料結構和使用場景1、String:2、hashlistsetzset

老規矩,先抛結論後驗證

redis五大資料結構和使用場景1、String:2、hashlistsetzset

string:有點像java的hashMap,存的時候什麼key,取的時候也什麼key,常用于做緩存,儲存使用者資訊、查詢清單等;

hash:這個有點像hashMap的value又套了個hashMap,下文有舉例,一看就明白了;

list:有序清單,類似Java的linkedList,可以在左邊右邊插入資料;

set:去重集合,類似Java的hashset,可用于求交集,比如共同好友;

zset:帶權重的set集合,可用于做排行榜;

為了友善了解,我們基于這個dog類來做測試,有手就能學會的那種

//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五大資料結構和使用場景1、String:2、hashlistsetzset

key可以随便設定,友善後面對比,我們這裡設定key為“string”,value就是dog

//set
jedis.set("string",dog1.toString());
//get
jedis.get("string");      

看下它在redis中長什麼樣 (左邊很多db,這個不用管,看db0就行)

redis五大資料結構和使用場景1、String:2、hashlistsetzset

如果有多個相同的key,前面的會被覆寫掉

jedis.set("string",dog1.toString());
        jedis.set("string",dog2.toString());
        jedis.set("string",dog3.toString());      
redis五大資料結構和使用場景1、String:2、hashlistsetzset

2、hash

說明:hashMap的value又套了個hashMap;

操作:hset方法,第一個參數是key,第二個參數是field,第三個參數是value

redis五大資料結構和使用場景1、String:2、hashlistsetzset

我還沒想到怎麼比較好的解釋這個field,說多了怕誤導你們,反正這個就像你new了個hashMap,然後這個hashMap的value又是個hashMap,然後你真正的資料是存在第二個hashMap裡面的

//類似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);
      

還沒懂的話就往下面看,别糾結上面那個舉例,我也不知道那樣說合理不合理

jedis.hset("hash", "field1", dog1.toString());
jedis.hset("hash", "field2", dog2.toString());
jedis.hset("hash", "field3", dog3.toString());      

看下在redis中長什麼樣

redis五大資料結構和使用場景1、String:2、hashlistsetzset

再看下hash類型在jedis中的方法應該就懂了

redis五大資料結構和使用場景1、String:2、hashlistsetzset

hget會讓你輸入兩個參數,第一個是key,第二個是field,這個方法直接傳回的是dog對象;

而hgetAll隻需要輸入一個參數,然後傳回一個map給你,這個map裡面裝的全是狗,懂了吧,如果你要擷取具體的dog對象,你還的輸入一個key,這個key就是那個field;

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

我們先插入一條蔡徐雞

redis五大資料結構和使用場景1、String:2、hashlistsetzset

然後在蔡徐雞的左右兩邊各插一條資料,

jedis.rpush("list",dog2.toString());//蔡徐公雞
jedis.lpush("list",dog3.toString());//蔡徐老母雞      
redis五大資料結構和使用場景1、String:2、hashlistsetzset

set

說明:去重集合,類似Java的set,可用于求交集,比如共同好友;

操作:放入元素sadd,求set的交集sinterstore,sinterstore方法可以有多個參數,因為這個方法會在redis生成一個set,用來存放交集,是以第一個參數是新生成set的名字,後面的參數全都是指定哪些set加入求交集方法

我們先設定兩個set,第一個set存放dog1和dog2,第二個set存放dog2和dog3

jedis.sadd("set1",dog1.toString(),dog2.toString());
jedis.sadd("set2",dog2.toString(),dog3.toString());      
redis五大資料結構和使用場景1、String:2、hashlistsetzset
redis五大資料結構和使用場景1、String:2、hashlistsetzset

我們再往set1裡面放個dog1試試

jedis.sadd("set1",dog1.toString());      

再看看redis的set1裡面有幾個dog1,既然是set,肯定不允許放入重複資料,是以應該跟上面一樣

redis五大資料結構和使用場景1、String:2、hashlistsetzset

我們再來看看如何擷取set的交集

目前set1裡面有蔡徐雞和蔡徐公雞,set2裡面有蔡徐公雞和蔡徐老母雞,那交集就是蔡徐公雞,來看看是不是

//這個方法會在redis生成一個set,用來存放交集
//第一個參數是指定新生成set的名字,後面的參數全都是指定哪些set加入求交集方法
jedis.sinterstore("set","set1","set2");      

來看下reids中有沒有生成一個叫set的key

redis五大資料結構和使用場景1、String:2、hashlistsetzset

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

zset

說明:帶權重的set集合,可用于做排行榜;

操作:添加元素zadd,需要指定元素的權重

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五大資料結構和使用場景1、String:2、hashlistsetzset

of course!!

----------------------------------------------------------------------分割線----------------------------------------------------------------------

說明:以上操作redis的方法僅作為了解redis資料類型舉例,實際上每個資料類型都還有很多很多其它方法,具體的本文不展開叙述,其次,我們生産中使用redis時,一定要記得給key設定過期時間,除開一些需要對key做持久化的場景,因為redis是運作在記憶體中的,如果所有key都持久存在于記憶體,你伺服器頂不住的鴨!!!