Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
Redis 中每个 hash 可以存储 2 - 1 键值对(40多亿)。

实例

127.0.0.1:6379> HMSET runoobkey name “redis tutorial” description “redis basic commands for caching” likes 20 visitors 23000
OK
127.0.0.1:6379> HGETALL runoobkey
1) “name”
2) “redis tutorial”
3) “description”
4) “redis basic commands for caching”
5) “likes”
6) “20”
7) “visitors”
8) “23000”
在以上实例中,我们设置了 redis 的一些描述信息(name, description, likes, visitors) 到哈希表的 runoobkey 中。


Redis hash 命令

下表列出了 redis hash 基本的相关命令:

序号 命令及描述
1 HDEL key field1 [field2]
删除一个或多个哈希表字段
2 HEXISTS key field
查看哈希表 key 中,指定的字段是否存在。
3 HGET key field
获取存储在哈希表中指定字段的值。
4 HGETALL key
获取在哈希表中指定 key 的所有字段和值
5 HINCRBY key field increment
为哈希表 key 中的指定字段的整数值加上增量 increment 。
6 HINCRBYFLOAT key field increment
为哈希表 key 中的指定字段的浮点数值加上增量 increment 。
7 HKEYS key
获取所有哈希表中的字段
8 HLEN key
获取哈希表中字段的数量
9 HMGET key field1 [field2]
获取所有给定字段的值
10 HMSET key field1 value1 [field2 value2 ]
同时将多个 field-value (域-值)对设置到哈希表 key 中。
11 HSET key field value
将哈希表 key 中的字段 field 的值设为 value 。
12 HSETNX key field value
只有在字段 field 不存在时,设置哈希表字段的值。
13 HVALS key
获取哈希表中所有值。
14 HSCAN key cursor [MATCH pattern] [COUNT count]
迭代哈希表中的键值对。

C# HashEntry与Object转换

  1. /// <summary>
  2. /// Converts to hash entry list.
  3. /// </summary>
  4. /// <typeparam name="T"></typeparam>
  5. /// <param name="instance">The instance.</param>
  6. /// <returns></returns>
  7. private IEnumerable<HashEntry> ConvertToHashEntryList<T>(T instance) where T : new()
  8. {
  9. Type objType = typeof(T);
  10. foreach (var prop in instance.GetType().GetProperties())
  11. {
  12. var type = prop.PropertyType;
  13. var underlyingType = Nullable.GetUnderlyingType(type);
  14. var effectiveType = underlyingType ?? type;
  15. var val = prop.GetValue(instance);
  16. if (val != null)
  17. {
  18. if (effectiveType == typeof(DateTime))
  19. {
  20. var date = (DateTime)val;
  21. if (date.Kind == DateTimeKind.Utc)
  22. {
  23. yield return new HashEntry(prop.Name, $"{date.Ticks}|UTC");
  24. }
  25. else
  26. {
  27. yield return new HashEntry(prop.Name, $"{date.Ticks}|LOC");
  28. }
  29. }
  30. else
  31. {
  32. yield return new HashEntry(prop.Name, val.ToString());
  33. }
  34. }
  35. }
  36. }
  37. /// <summary>
  38. /// Converts to object.
  39. /// </summary>
  40. /// <typeparam name="T"></typeparam>
  41. /// <param name="hashEntries">The hash entries.</param>
  42. /// <param name="ignoreFail">if set to <c>true</c> [ignore fail].</param>
  43. /// <returns>T.</returns>
  44. private T ConvertFromHashEntryList<T>(HashEntry[] hashEntries)
  45. {
  46. Type objType = typeof(T);
  47. T instance = (T)Activator.CreateInstance(objType);
  48. foreach (var prop in instance.GetType().GetProperties())
  49. {
  50. var entry = hashEntries.FirstOrDefault(e => e.Name.ToString().Equals(prop.Name));
  51. if (entry == null || entry.Equals(new HashEntry()) || !entry.Value.HasValue)
  52. {
  53. continue;
  54. }
  55. var type = prop.PropertyType;
  56. var underlyingType = Nullable.GetUnderlyingType(type);
  57. var effectiveType = underlyingType ?? type;
  58. if (effectiveType == typeof(DateTime))
  59. {
  60. var value = entry.Value.ToString();
  61. if (string.IsNullOrEmpty(value))
  62. {
  63. continue;
  64. }
  65. DateTime date;
  66. long ticks;
  67. if (value.EndsWith("|UTC"))
  68. {
  69. value = value.TrimEnd("|UTC".ToCharArray());
  70. if (long.TryParse(value, out ticks))
  71. {
  72. date = new DateTime(ticks);
  73. prop.SetValue(instance, DateTime.SpecifyKind(date, DateTimeKind.Utc));
  74. }
  75. }
  76. else if (value.EndsWith("|LOC"))
  77. {
  78. value = value.TrimEnd("|LOC".ToCharArray());
  79. if (long.TryParse(value, out ticks))
  80. {
  81. date = new DateTime(ticks);
  82. prop.SetValue(instance, DateTime.SpecifyKind(date, DateTimeKind.Local));
  83. }
  84. }
  85. else
  86. {
  87. string dateTimeFormat = "yyyy-MM-dd HH:mm:ss";
  88. value = value.Replace("\"", string.Empty);
  89. date = DateTime.ParseExact(value, dateTimeFormat, CultureInfo.InvariantCulture);
  90. prop.SetValue(instance, date);
  91. }
  92. }
  93. else
  94. {
  95. prop.SetValue(instance, Convert.ChangeType(entry.Value, effectiveType));
  96. }
  97. }
  98. return instance;
  99. }

更多命令请参考:https://redis.io/commands
https://www.runoob.com/redis/redis-hashes.html
https://redis.io/commands#hash