RedisTemplate的execute和executePiplined方法的使用如下所示:
@Autowired
private RedisTemplate<String, Object> redisTemplate;
User user=new User("1234","张三","male");
String key="lock4";
// 使用Execute来执行
redisTemplate.execute(new RedisCallback<Boolean>() {
@Override
public Boolean doInRedis(RedisConnection connection) throws DataAccessException {
connection.setNX(user.getId().getBytes(), (user.getName()+":"+user.getSex()).getBytes());
// 返回值必须为null,否则会抛出异常
return null;
}
});
// 使用ExecutePipelined来执行
RedisCallback<Boolean> action=new RedisCallback<Boolean>() {
@Override
public Boolean doInRedis(RedisConnection connection) throws DataAccessException {
long[] offsets=LongStream.range(1, 4).toArray();
for (long offset : offsets) {
connection.setBit(key.getBytes(), offset, true);
}
// 返回值必须为null,否则会抛出异常
return null;
}
};
List<Object> results=redisTemplate.executePipelined(action);
results.stream().forEach(x->System.out.println(x));// 输出的结果为:true true true
// 这里也可以使用execute方法来执行
Boolean result=redisTemplate.execute(action);// result的结果为null
由以上的内容和执行结果可以看出,execute和executePiplined两个方法都可以用来执行多个Redis命令,但是executePiplined方法可以返回每一条Redis命令执行后的结果
,而execute方法的执行结果为null。