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,望技術有成后能回來看見自己的腳步