RedisTemplate中的Execute方法和ExecutePiplined方法比较

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。

你可能感兴趣的:(Redis,SpringBoot,redis,springboot)