java使用redisTemplate.opsForValue().increment(key, delta);出现ERR value is not an integer or out of rang

关于java中redis使用自增时,出现ERR value is not an integer or out of range错误总结。
首先数据量不大,使用这个自增,目的是保证数据的一致性。
第一次用redis自增,思路如下:

//1.首先肯定做判断(判断key是否存在):
redisTemplate.hasKey(key);
//如果不存在就创建()
redisTemplate.opsForValue().set(key, "1");
//创建成功后,自增
redisTemplate.opsForValue().increment(key, 1);

//这一番操作后,不出意外的话,出现的意外,报错了ERR value is not an integer or out of range
//我就根据这个报错去找原因,网上查找解决办法,最终没解决,但也学习到点东西。
/**
这个可以参看看学习有的人能用这个解决,https://blog.csdn.net/weixin_42829048/article/details/83989784
问题就出在这里,序列化的问题:
只有使用StringRedisSerializer序列化器才能使用incrment方法
**/

//我看了看,用set方法去创建时,value值不能随便,也就是说不是自增出了问题,就创建的时候就有问题了,
//咋解决
1.首先肯定做判断(判断key是否存在):
redisTemplate.hasKey(key);
2.直接自增(没有key可以自动生成,默认值为0,返回值为value值);)
long value = redisTemplate.opsForValue().increment(key, 1);
(还有就是redisTemplate.expire(key, time);也行,expire方法是设置redis对应key有效时间)
记录一下
 String dbcode ="";
            SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd");
            String key = "Q" + dateFormat.format(new Date());
            if(!redisUtil.hasKey(key)){
//                Integer defaultCount = 1;
//                redisUtil.set(key, defaultCount, 60);
//                redisUtil.set(key, "1", 60);
                redisUtil.incr(key,1);
                redisUtil.expire(key,getSecondsNextEarlyMorning());
            }
            long count = redisUtil.incr(key,1)-1;
            String formattedNumber = String.format("%04d", count);
            dbcode = key + formattedNumber;

 //计算到明天8点差多少秒,设置过期时间
    public Long getSecondsNextEarlyMorning() {
        Calendar cal = Calendar.getInstance();
        cal.add(Calendar.DAY_OF_YEAR, 1);
        cal.set(Calendar.HOUR_OF_DAY, 8);
        cal.set(Calendar.SECOND, 0);
        cal.set(Calendar.MINUTE, 0);
        cal.set(Calendar.MILLISECOND, 0);
        return (cal.getTimeInMillis() - System.currentTimeMillis()) / 1000;
    }
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果在使用 Spring Data Redis 的 `increment` 方法进行自增操作时,出现了 `ERR value is not an integer or out of range` 的错误,可能是因为 Redis 中对应的键存储的值不是整数类型,或者存储的整数值超出了 Redis 数据类型的范围。 为了解决这个问题,你可以在调用 `increment` 方法之前,先使用 RedisTemplate 的 `type` 方法获取 Redis 中对应键的数据类型,如果是字符串类型,就尝试将其转换为整数类型。如果转换失败,就抛出异常或者返回错误信息,避免出现 `ERR value is not an integer or out of range` 的错误。 示例代码如下: ```java @Autowired private RedisTemplate<String, Object> redisTemplate; public Long incrementCounter(String key, long delta) { DataType dataType = redisTemplate.type(key); if (dataType == DataType.STRING) { Object value = redisTemplate.opsForValue().get(key); if (value == null) { redisTemplate.opsForValue().set(key, delta); return delta; } else { try { Long longValue = Long.parseLong(value.toString()); return redisTemplate.opsForValue().increment(key, delta); } catch (NumberFormatException e) { throw new RuntimeException("Value is not an integer: " + value); } } } else { throw new RuntimeException("Key is not a string: " + key); } } ``` 上述代码中,`redisTemplate` 是一个已经通过 Spring 配置注入的 RedisTemplate 对象,泛型参数 `<String, Object>` 表示 Redis 中键名和键值的数据类型。`incrementCounter` 方法接受一个键名和自增步长,首先使用 `type` 方法获取 Redis 中对应键的数据类型,如果是字符串类型,就尝试将其转换为整数类型。如果转换失败,就抛出异常或者返回错误信息;如果转换成功,就调用 `increment` 方法实现自增操作,并返回自增后的结果。如果键名对应的数据类型不是字符串类型,也会抛出异常或者返回错误信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值