Redis 从入门到精通之Redis数据排序

本文涉及的产品
云原生网关 MSE Higress,422元/月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: Redis支持对List、Set和Sorted Set元素进行排序,排序命令是`SORT`。`SORT`命令可以根据指定的排序规则对列表、集合或有序集合的元素进行排序,并返回排序后的元素列表或子集。使用Jedis和RedisTemplate分别实现Redis列表、集合和有序集合排序操作的示例代码

前言

redis支持对list,set和sorted set元素的排序。排序命令是sort 完整的命令格式如下:

SORT key [BY pattern] [LIMIT start count] [GET pattern] [ASC|DESC] [ALPHA] [STORE dstkey]

复杂度为O(N+M*log(M))。(N是集合大小,M 为返回元素的数量)

1. Redis 排序命令

Redis支持对List、Set和Sorted Set元素进行排序,排序命令是SORTSORT命令可以根据指定的排序规则对列表、集合或有序集合的元素进行排序,并返回排序后的元素列表或子集。

SORT命令的完整语法如下:

SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALPHA] [STORE destination]

其中,各参数的含义如下:

  • key:要排序的列表、集合或有序集合的键名。
  • BY pattern:可选项,指定排序时使用的外部键名模式。
  • LIMIT offset count:可选项,指定要排序的元素范围。
  • GET pattern [GET pattern ...]:可选项,指定要返回的元素属性。
  • ASC|DESC:可选项,指定排序方式,升序或降序,默认为升序。
  • ALPHA:可选项,指定按字典序排序,仅适用于字符串类型。
  • STORE destination:可选项,指定将排序结果保存到指定键名的新列表中。

2.Jedis和RedisTemplate redis排序实现

以下是使用Jedis和RedisTemplate分别实现Redis列表、集合和有序集合排序操作的示例代码:

2.1 Jedis实现:

import redis.clients.jedis.Jedis;
import java.util.List;
import java.util.Set;

public class JedisExample {
   
    public static void main(String[] args) {
   
        // 连接Redis
        Jedis jedis = new Jedis("localhost", 6379);

        // 添加元素到List
        jedis.lpush("list", "60", "75", "80", "90", "85");
        // 对List元素进行排序
        List<String> sortedList = jedis.sort("list");
        // 输出排序结果
        System.out.println(sortedList);

        // 添加元素到Set
        jedis.sadd("set", "60", "75", "80", "90", "85");
        // 对Set元素进行排序
        Set<String> sortedSet = jedis.sort("set");
        // 输出排序结果
        System.out.println(sortedSet);

        // 添加元素到Sorted Set
        jedis.zadd("zset", 60, "Tom");
        jedis.zadd("zset", 75, "Jerry");
        jedis.zadd("zset", 80, "Alice");
        jedis.zadd("zset", 90, "Bob");
        jedis.zadd("zset", 85, "Charlie");
        // 对Sorted Set元素进行排序
        Set<String> sortedZSet = jedis.sort("zset");
        // 输出排序结果
        System.out.println(sortedZSet);

        // 关闭连接
        jedis.close();
    }
}

2.2 RedisTemplate实现:

import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ListOperations;
import org.springframework.data.redis.core.SetOperations;
import org.springframework.data.redis.core.ZSetOperations;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import java.util.List;
import java.util.Set;

public class RedisTemplateExample {
   
    public static void main(String[] args) {
   
        // 创建RedisTemplate对象
        RedisTemplate<String, String> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(new JedisConnectionFactory());

        // 设置key和value的序列化方式
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(new StringRedisSerializer());

        // 初始化RedisTemplate
        redisTemplate.afterPropertiesSet();

        // 获取List类型操作对象
        ListOperations<String, String> listOps = redisTemplate.opsForList();
        // 添加元素到List
        listOps.leftPushAll("list", "60", "75", "80", "90", "85");
        // 对List元素进行排序
        List<String> sortedList = listOps.sort("list");
        // 输出排序结果
        System.out.println(sortedList);

        // 获取Set类型操作对象
        SetOperations<String, String> setOps = redisTemplate.opsForSet();
        // 添加元素到Set
        setOps.add("set", "60", "75", "80", "90", "85");
        // 对Set元素进行排序
        Set<String> sortedSet = setOps.sort("set");
        // 输出排序结果
        System.out.println(sortedSet);

        // 获取ZSet类型操作对象
        ZSetOperations<String, String> zSetOps = redisTemplate.opsForZSet();
        // 添加元素到Sorted Set
        zSetOps.add("zset", "Tom", 60);
        zSetOps.add("zset", "Jerry", 75);
        zSetOps.add("zset", "Alice", 80);
        zSetOps.add("zset", "Bob", 90);
        zSetOps.add("zset", "Charlie", 85);
        // 对Sorted Set元素进行排序
        Set<String> sortedZSet = zSetOps.range("zset", 0, -1);
        // 输出排序结果
        System.out.println(sortedZSet);

        // 关闭RedisTemplate连接
        redisTemplate.getConnectionFactory().getConnection().close();
    }
}

3.注意事项

  1. 只有列表、集合和有序集合类型的数据结构支持排序操作。其他类型的数据结构不支持排序操作。

  2. 在使用SORT命令对数据结构进行排序之前,需要先向数据结构中添加元素。

  3. SORT命令支持对数据结构中的元素按照字典序、数字大小或者自定义规则进行排序。

  4. 在对有序集合进行排序时,需要使用ZSET类型的操作对象,并使用range方法获取有序集合的元素范围。

  5. 在使用RedisTemplate进行排序操作时,需要先设置key和value的序列化方式,并在操作完成后关闭RedisTemplate连接。

  6. 在使用Jedis进行排序操作时,需要在操作完成后关闭Jedis连接。

4.总结

使用Jedis和RedisTemplate分别实现Redis列表、集合和有序集合排序操作的示例。在示例代码中,我们向列表、集合和有序集合中添加元素,然后使用SORT命令对元素进行排序,并将排序结果输出。需要注意的是,在对有序集合元素进行排序时,需要使用ZSET类型的操作对象,并使用range方法获取有序集合的元素范围。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1月前
|
NoSQL Redis
Redis的数据淘汰策略有哪些 ?
Redis 提供了 8 种数据淘汰策略,分为淘汰易失数据和淘汰全库数据两大类。易失数据淘汰策略包括:volatile-lru、volatile-lfu、volatile-ttl 和 volatile-random;全库数据淘汰策略包括:allkeys-lru、allkeys-lfu 和 allkeys-random。此外,还有 no-eviction 策略,禁止驱逐数据,当内存不足时新写入操作会报错。
107 16
|
3天前
|
缓存 NoSQL Redis
Redis经典问题:数据并发竞争
数据并发竞争是大流量系统(如火车票系统、微博平台)中常见的问题,可能导致用户体验下降甚至系统崩溃。本文介绍了两种解决方案:1) 加写回操作加互斥锁,查询失败快速返回默认值;2) 保持多个缓存备份,减少并发竞争概率。通过实践案例展示,成功提高了系统的稳定性和性能。
|
3天前
|
缓存 监控 NoSQL
Redis经典问题:数据不一致
在使用Redis时,缓存与数据库数据不一致会导致应用异常。主要原因包括缓存更新失败、Rehash异常等。解决方案有:重试机制、缩短缓存时间、优化写入策略、建立监控报警、定期验证一致性、采用缓存分层及数据回滚恢复机制。这些措施可确保数据最终一致性,提升应用稳定性和性能。
|
1月前
|
缓存 NoSQL 关系型数据库
Redis和Mysql如何保证数据⼀致?
在项目中,为了解决Redis与Mysql的数据一致性问题,我们采用了多种策略:对于低一致性要求的数据,不做特别处理;时效性数据通过设置缓存过期时间来减少不一致风险;高一致性但时效性要求不高的数据,利用MQ异步同步确保最终一致性;而对一致性和时效性都有高要求的数据,则采用分布式事务(如Seata TCC模式)来保障。
67 14
|
1月前
|
缓存 NoSQL PHP
Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出
本文深入探讨了Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出。文章还介绍了Redis在页面缓存、数据缓存和会话缓存等应用场景中的使用,并强调了缓存数据一致性、过期时间设置、容量控制和安全问题的重要性。
43 5
|
1月前
|
存储 NoSQL 算法
Redis分片集群中数据是怎么存储和读取的 ?
Redis集群采用哈希槽分区算法,共有16384个哈希槽,每个槽分配到不同的Redis节点上。数据操作时,通过CRC16算法对key计算并取模,确定其所属的槽和对应的节点,从而实现高效的数据存取。
52 13
|
1月前
|
存储 NoSQL Redis
Redis的数据过期策略有哪些 ?
Redis 采用两种过期键删除策略:惰性删除和定期删除。惰性删除在读取键时检查是否过期并删除,对 CPU 友好但可能积压大量过期键。定期删除则定时抽样检查并删除过期键,对内存更友好。默认每秒扫描 10 次,每次检查 20 个键,若超过 25% 过期则继续检查,单次最大执行时间 25ms。两者结合使用以平衡性能和资源占用。
50 11
|
1月前
|
监控 NoSQL 测试技术
【赵渝强老师】Redis的AOF数据持久化
Redis 是内存数据库,提供数据持久化功能,支持 RDB 和 AOF 两种方式。AOF 以日志形式记录每个写操作,支持定期重写以压缩文件。默认情况下,AOF 功能关闭,需在 `redis.conf` 中启用。通过 `info` 命令可监控 AOF 状态。AOF 重写功能可有效控制文件大小,避免性能下降。
|
1月前
|
存储 监控 NoSQL
【赵渝强老师】Redis的RDB数据持久化
Redis 是内存数据库,提供数据持久化功能以防止服务器进程退出导致数据丢失。Redis 支持 RDB 和 AOF 两种持久化方式,其中 RDB 是默认的持久化方式。RDB 通过在指定时间间隔内将内存中的数据快照写入磁盘,确保数据的安全性和恢复能力。RDB 持久化机制包括创建子进程、将数据写入临时文件并替换旧文件等步骤。优点包括适合大规模数据恢复和低数据完整性要求的场景,但也有数据完整性和一致性较低及备份时占用内存的缺点。
|
1月前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法