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;
}
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
