• 【redis实现自增流水并设置过期时间】


    如果你需要一个自增的两位流水号,可以使用RedisINCR命令结合一些逻辑来实现。

    以下是一个修正后的示例代码

    import org.springframework.data.redis.core.StringRedisTemplate;
    
    import java.time.LocalDateTime;
    import java.time.format.DateTimeFormatter;
    import java.util.concurrent.TimeUnit;
    
    public class SerialNumberGenerator {
        private StringRedisTemplate redisTemplate;
        private static final String KEY_PREFIX = "serial_number:";
        private static final String DATE_FORMAT = "yyyyMMddHHmm";
    
        public SerialNumberGenerator(StringRedisTemplate redisTemplate) {
            this.redisTemplate = redisTemplate;
        }
    
        public String generateSerialNumber() {
            LocalDateTime now = LocalDateTime.now();
            String key = KEY_PREFIX + now.format(DateTimeFormatter.ofPattern(DATE_FORMAT));
    
            Long serialNumber = redisTemplate.opsForValue().increment(key, 1);
            if (serialNumber == 1) {
                redisTemplate.expire(key, 1, TimeUnit.MINUTES);
            }
    
            String formattedSerialNumber = String.format("%02d", serialNumber);
            return formattedSerialNumber;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    在这个修正后的示例中,我们使用Redis的INCR命令来实现递增操作。首先,我们根据当前日期和时间生成一个唯一的键,然后使用opsForValue().increment()方法对该键的值进行递增操作。

    如果递增后的值为1,表示新的一分钟开始了,我们使用expire()方法设置键的过期时间为1分钟。

    最后,我们使用String.format("%02d", serialNumber)将流水号格式化为两位字符串,并返回生成的流水号。

    请确保在实例化SerialNumberGenerator时将合适的StringRedisTemplate传递给它,并在Spring应用程序中使用该类来获取自增的两位流水号,并且每分钟重置。

    非常抱歉给你带来的困扰,感谢你的指正。如果还有其他问题,请随时提问。

  • 相关阅读:
    【quartz】从数据库中读取配置实现动态定时任务
    基于XML的Web服务Java接口(JAX-WS)、Jakarta XML Web Services Eclipse 实现
    【PID控制技术】
    Maven 笔记
    走近足球运动·与棒球相似的体育项目·第一堂棒球课
    SpringBoot学习(八)——Swagger
    C++:static关键字
    腾讯云大数据ES Serverless
    linux之perf(4)stat统计
    ORA-01005 vs ORA-28040
  • 原文地址:https://blog.csdn.net/zhijingege/article/details/134034798