redis sorted Set命令基本使用

场景:需要查询学生考试成绩情况

sorted Set数据默认排序是按分数的小到大排序的

zAdd 添加数据

复制代码
$redis = new Redis();
$redis->connect('127.0.0.1', 6379); // 连接到Redis服务器

// 假设我们有10个学生和他们对应的分数
$students = [
    ['name' => 'Alice', 'score' => 85],
    ['name' => 'Bob', 'score' => 92],
    ['name' => 'Charlie', 'score' => 78],
    ['name' => 'David', 'score' => 95],
    ['name' => 'Eva', 'score' => 88],
    ['name' => 'Frank', 'score' => 90],
    ['name' => 'Grace', 'score' => 83],
    ['name' => 'Heidi', 'score' => 93],
    ['name' => 'Ivan', 'score' => 87],
    ['name' => 'Judy', 'score' => 91],
];

// 将学生添加到有序集合中
foreach ($students as $student) {
    $redis->zAdd('user_score', $student['score'], $student['name']);
}

zCard 获取有序集合的大小

复制代码
// 获取有序集合的大小
$setSize = $redis->zCard('user_score');

zCount 获取60分到80分之间的成员数量

复制代码
// 获取60分到80分之间的成员数量
$count = $redis->zCount('user_score', 60, 80);

zScore 获取指定同学的分数

复制代码
// 获取指定同学的分数
$score = $redis->zScore('user_score', $studentName);

zIncrBy 给指定同学增加分数

复制代码
// 假设我们要给名为"Alice"的同学加10分
$studentName = 'Alice';
$scoreIncrement = 10;

// 给指定同学增加分数
$newScore = $redis->zIncrBy('user_score', $scoreIncrement, $studentName);

zRem 删除名为"Alice"的学生

复制代码
// 假设我们要删除名为"Alice"的学生
$studentName = 'Alice';

// 删除指定的学生
$deleted = $redis->zRem('user_score', $studentName);

zRemRangeByRank 删除排名最后的3名同学

复制代码
// 删除排名最后的3名同学
$deletedCount = $redis->zRemRangeByRank('user_score', -3, -1);

zRemRangeByScore 删除分数在50分到60分之间的同学

复制代码
// 删除分数在50分到60分之间的同学
$deletedCount = $redis->zRemRangeByScore('user_score', 50, 60);

zRank 获取指定同学的排名,小到大排

复制代码
// 获取指定同学的排名
$rank = $redis->zRank('user_score', $studentName);

zRevRank 获取指定同学的逆序排名,大到小排

复制代码
// 获取指定同学的逆序排名
$rank = $redis->zRevRank('user_score', $studentName);

zRevRange 查询分数最高的3名同学

复制代码
// 获取分数最高的前3名同学
$topStudents = $redis->zRevRange('user_score', 0, 2, ['withscores' => true]);

zRange 获取分数最低的5名同学

复制代码
//获取分数最低的5名同学
$lowestStudents = $redis->zRange('user_score', 0, 4, ['withscores' => true]);

zRangeByScore 获取60分以上的所有同学,分数小到大排序,60,61,62

复制代码
// 获取60分以上的所有同学
$studentsAboveSixty = $redis->zRangeByScore('user_score', 60, '+inf', ['withscores' => true]);

zRevRangeByScore 获取60分以上的所有同学,分数倒序排序 100, 99, 98

复制代码
// 获取60分以上的所有同学,分数倒序排序
$studentsAboveSixtyDesc = $redis->zRevRangeByScore('user_score', '+inf', 60, ['withscores' => true]);
相关推荐
cookqq5 分钟前
MySQL 5.7 大表删除部分数据:.ibd 文件会变小吗?磁盘会释放吗?
数据结构·数据库·mysql
IT 行者10 分钟前
告别硬编码!Spring Boot 优雅实现 Controller 路径前缀统一管理
数据库·spring boot·python
曹牧18 分钟前
Oracle 大表数据分区存储
数据库·oracle
win x23 分钟前
Redis 持久化
数据库·redis·缓存
程序猿202338 分钟前
MySQL的锁(行锁)
数据库·mysql
W001hhh1 小时前
数据库实训Day005下午
数据库
optimistic_chen1 小时前
【Redis系列】Java操作Redis客户端
java·linux·redis·客户端·服务端
lechcat1 小时前
多角色协同巡检流程设计技术教程
大数据·数据库·数据挖掘
小沈同学呀1 小时前
基于时间片划分的提醒算法设计与实现
服务器·数据库·算法
曹牧1 小时前
Oracle:单一索引和联合索引
数据库·oracle