初探Redis-基礎類型Hash


  Redis存在五種基礎類型:字符串(String)、列表(List)、哈希(Hash)、集合(Set)、有序集合(Sorted Set)。本次列舉出Hash的常用操作。

  Redis官網:https://redis.io/ 

 

一、哈希(Hash)介紹

  哈希(Hash)是Redis 中基本的類型,一個 key 對應着一個集合,其中集合中以field-value形式組成一個字典。可以理解為一個字典中,單項值部分又是一個字典。每個哈希(Hash)可以存儲2^32-1個鍵值對。數據序列化成json格式為{key:{field1:value1,field2:value2......fieldN:valueN}}。

  • 內部用zipmap結構存儲,以節約空間
  • 更新方便,只需更新field對應value值即可更新。

  

 

二、哈希(Hash)常用Api 

  • 設置field-value

  

  

  • 設置初次添加的field-value

  

  •  獲取值

   

   

  • 批量設置值

  

  

  •  批量獲取值

   

  

  •  獲取key下集合信息

  

   

  •  獲取key下所有field

  

  

  •  獲取key下所有value

  

   

  •  刪除key下的field

  

   

 

三、哈希(Hash)不常用Api 

  • 查詢key下field是否存在

   

  

  • 遞增key下field映射值(△n)

  

   

  • 遞增key下field映射值(△n 浮點數)

  

  

  • 獲取key下field數量

    

  

  • 獲取key下field映射值的長度

  

   

  • 迭代哈希表中的鍵值對

  

   數量有限,返回游標仍然是0。

   

 

四、哈希(Hash)簡單應用場景

  模擬文章概要信息的Hash存儲並快速獲取,場景如下,網站首頁分頁展示文章概要信息,定義為熱區文章,如某文章更改內容,則先判定是否該文章id屬於熱區,如屬於則更改Hash中field對應的值。

1、模擬文章數據,設置一堆種子

var blogOutlineInfoList = new List<BlogOutlineInfo>()
{
    new BlogOutlineInfo()
    {
        Id = "9527",
        Title = "CSharp",
        Author = "微笑刺客",
        CreateTime = DateTime.Now,
        Content = "CSharp從入門到升仙",
        CommentCount =0,
        ReadCount = 0,
        RecommendCount = 0
    },
    new BlogOutlineInfo()
    {
        Id = "9528",
        Title = "Mysql",
        Author = "微笑刺客",
        CreateTime = DateTime.Now,
        Content = "Mysql從入門到遁地",
        CommentCount =0,
        ReadCount = 0,
        RecommendCount = 0
    },
    new BlogOutlineInfo()
    {
        Id = "9529",
        Title = "Docker",
        Author = "微笑刺客",
        CreateTime = DateTime.Now,
        Content = "Docker從入門到轉行",
        CommentCount =0,
        ReadCount = 0,
        RecommendCount = 0
    },
    ...
};

 2、將種子數據加入到Redis中(緩存預熱)

foreach (var blogOutlineInfo in blogOutlineInfoList)
{
    //設置Redis_key
    var blogOutlineInfoKey = $"blogOutlineInfo_{blogOutlineInfo.Id}";

    //初始化屬性值
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.Title), blogOutlineInfo.Title);
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.Content), blogOutlineInfo.Content);
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.Author), blogOutlineInfo.Author);
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.CreateTime), blogOutlineInfo.CreateTime);
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.CommentCount), blogOutlineInfo.CommentCount);
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.ReadCount), blogOutlineInfo.ReadCount);
    service.HashSet(blogOutlineInfoKey, nameof(BlogOutlineInfo.RecommendCount), blogOutlineInfo.RecommendCount);
}

 3、網站中對於某頁需要的數據,根據當前頁面,先從Redis的List中獲取相關文章Id,然后再從Hash中獲取文章概要信息。

 

4、模擬某文章增加推薦、評論或是訪問量。

#region 增加推薦數量
service.HashIncrement("blogOutlineInfo_9527", "RecommendCount", 1);
#endregion

#region 更改簡介內容
service.HashSet("blogOutlineInfo_9530", "Content", "k8s從入門到失業");
#endregion

#region 增加閱讀量
service.HashIncrement("blogOutlineInfo_9528", "ReadCount", 1);
#endregion

 5、運行效果,對於第一篇的推薦數量和第二篇的閱讀數量可直接進行更改。

 

  

 倉庫地址:https://gitee.com/530521314/Partner.TreasureChest.git(RedisOperate文件夾)

2020-05-13,望技術有成后能回來看見自己的腳步


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM