
第一部分:Redis的哈希(Hash)和SET到底是什么?
1. 哈希(Hash)
- 生活中的例子:
想象一下,你有一个工具箱,里面装着各种工具:螺丝刀、锤子、扳手……每个工具都有自己的名字(比如“螺丝刀”),并且每个工具都有对应的用途(比如“拧螺丝”)。 - 在Redis里:
Redis的哈希(Hash)就是一个工具箱,它用来存储一组键值对(Key-Value)。每个键(Field)对应一个值(Value),适合存储对象(如用户信息)。
2. SET
- 生活中的例子:
想象一下,你有一堆球,每个球都不重复,并且没有顺序。你可以随时添加或移除球,但不能有重复的球。 - 在Redis里:
Redis的SET是一个无序的集合,存储的值不能重复,适合需要去重的场景。
第二部分:两者的异同包含哪些部分?
1. 主要组成部分
特性 | 哈希(Hash) | SET |
---|
结构 | 键值对(Field-Value) | 单个值 |
是否有序 | 无序 | 无序 |
是否允许重复 | 字段唯一,值可以重复 | 值唯一,不允许重复 |
典型用途 | 存储对象(如用户信息) | 去重、记录唯一值 |
第三部分:背后到底做了哪些事情?
1. 哈希(Hash)的工作原理
- 存储数据:将一组键值对存储到哈希中。
- 读取数据:根据字段名获取对应的值。
- 更新数据:修改某个字段的值。
- 删除数据:移除某个字段或整个哈希。
2. SET的工作原理
- 存储数据:向集合中添加值,确保值不重复。
- 读取数据:获取集合中的所有值。
- 删除数据:从集合中移除某个值。
3. 底层实现
- 哈希(Hash):
- 使用哈希表(Hash Table)或压缩列表(Ziplist)存储数据。
- 当字段数量较少时,使用压缩列表以节省内存;当字段数量较多时,切换到哈希表。
- SET:
- 使用哈希表存储数据,确保值的唯一性。
- 内部通过哈希函数快速定位值的位置。
第四部分:示例代码与详细讲解
1. 示例代码:哈希(Hash)的操作
<?php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->hSet('user:1', 'name', '小明');
$redis->hSet('user:1', 'age', 5);
$name = $redis->hGet('user:1', 'name');
echo "用户名是:$name\n";
$userInfo = $redis->hGetAll('user:1');
echo "用户信息:" . json_encode($userInfo) . "\n";
$redis->hSet('user:1', 'age', 6);
$newAge = $redis->hGet('user:1', 'age');
echo "新的年龄是:$newAge\n";
$redis->hDel('user:1', 'age');
$updatedUserInfo = $redis->hGetAll('user:1');
echo "删除 age 后的用户信息:" . json_encode($updatedUserInfo) . "\n";
2. 示例代码:SET的操作
<?php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->sAdd('balls', '红球');
$redis->sAdd('balls', '蓝球');
$redis->sAdd('balls', '红球');
$balls = $redis->sMembers('balls');
echo "球的集合:" . json_encode($balls) . "\n";
$isRedBall = $redis->sIsMember('balls', '红球');
echo "红球是否在集合中:" . ($isRedBall ? "是" : "否") . "\n";
$redis->sRem('balls', '蓝球');
$updatedBalls = $redis->sMembers('balls');
echo "删除 蓝球 后的集合:" . json_encode($updatedBalls) . "\n";
第五部分:使用场景
1. 哈希(Hash)的使用场景
- 用户信息存储:存储用户的姓名、年龄、城市等。
- 对象缓存:缓存商品信息、订单信息等复杂对象。
- 配置管理:存储系统的配置项,比如数据库连接信息。
2. SET的使用场景
- 去重:记录用户已购买的商品ID。
- 社交网络:存储用户的好友列表。
- 统计:记录访问过的IP地址。
第六部分:底层原理是什么?
1. 哈希(Hash)的底层原理
- 哈希表(Hash Table):
- 当字段数量较多时,使用哈希表存储数据。
- 哈希表通过计算哈希值快速定位字段的位置。
- 压缩列表(Ziplist):
- 当字段数量较少且值较小时,使用压缩列表以节省内存。
2. SET的底层原理
- 哈希表(Hash Table):
- 使用哈希表存储集合中的值,确保值的唯一性。
- 内部通过哈希函数快速定位值的位置。
第七部分:总结
1. 哈希(Hash)和SET的本质
- 哈希(Hash):
- 是一个工具箱,用来存储一组键值对,适合存储复杂对象。
- SET:
- 是一堆球,用来存储一组唯一的值,适合需要去重的场景。
2. 生活中的类比
- 哈希(Hash)就像一个工具箱,每个工具都有自己的名字和用途。
- SET就像一堆球,每个球都不重复,适合需要去重的场景。