使用Redis管道机制Pipeline批量操作

该博客展示了如何在Java中利用@Autowired的RedisTemplate执行Redis的管道(pipeline)操作,通过设置键值对来批量存储数据。博客中提到了使用StringRedisSerializer进行序列化,并讨论了不同序列化方式对数据存储的影响。同时,还注意到了直接使用模板方法可能产生的额外引号问题,这可能影响数据的获取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@Component
public class redispipe {

    @Autowired
    RedisTemplate redisTemplate;
    
    StringRedisSerializer serialize = new StringRedisSerializer();

	@Scheduled(fixedDelay = 1000 * 60)
    private void make(){
        List<UserEntity> userList = new ArrayList<>(); //模拟数据
        executePipeline(userList);
    }
    
    private void executePipeline(List<UserEntity> list){
        redisTemplate.executePipelined(new RedisCallback<Object>() {
            @Override
            public Object doInRedis(RedisConnection redisConnection) throws DataAccessException {
                list.forEach(item->{
                    String key = item.getName();
                    String value = item.getAge();
                    //进行redis操作
                    redisConnection.set(key.getBytes(),value.getBytes());
                    //或者
                    redisConnection.set(serialize.serialize(key),serialize.serialize(value));
                    
                    //也可以使用下面这种,但是不推荐,会加多个双引号  如原本是 【张三:18】 存到redis会变 【"张三":"18"】 不方便get
                    redisConnection.set(redisTemplate.getKeySerializer().serialize(key)
                            ,redisTemplate.getKeySerializer().serialize(value));
                });
                return null;
            }
        });
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值