代码:import org.springframework.data.redis.core.StringRedisTemplate;@Autowiredprivate StringRedisTemplate stringRedisTemplate;比如Redis中存放的是set,// members()里是Redis里的key,set是对应的value...
代码:
import org.springframework.data.redis.core.StringRedisTemplate;
@Autowired
private StringRedisTemplate stringRedisTemplate;
比如Redis中存放的是set,
// members()里是Redis里的key,set是对应的value
Set<String> dataSet = stringRedisTemplate.opsForSet().members("jj:loginlimit:whiteTestUser");
// 获取所有形如某pattern的key,例如 jj:mil:20180909:400, jj:mil:20180909:200
Set<String> set = stringRedisTemplate.keys("jj:mil:"+"20180909:" + "*");
此外,还有一种写法:
// 每次connection的返回结果是RedisCallback<Void>,每次连接就从事一次增删改查
stringRedisTemplate.execute( (RedisCallback<Void>) connection -> {
// 逻辑开始
String messageContent = new String(connection.get(key.getBytes()), Charset.defaultCharset());
。。。
// 逻辑结束
return null;
});
这种写法与上面的opsForSet()之类的写法的差别?
析:实际上opsForSet() 之后的get set等也是调用了execute方法。那么这种写法有何优点?
如果有循环数据操作,可以把每次的操作都放在逻辑代码处,直到return null才会释放对redis的连接。
stringRedisTemplate.execute( (RedisCallback<Void>) connection -> {
for(String key:keys){
例如 connection.get(key.getBytes()) 增删改查
}
return null;
});
更多见:https://www.cnblogs.com/slowcity/p/9002660.html
沃梦达教程
本文标题为:ex:Redis使用代码
猜你喜欢
- Numpy中如何创建矩阵并等间隔抽取数据 2023-07-28
- 基于Python制作一个简单的文章搜索工具 2023-07-28
- redis清除数据 2023-09-13
- SQL Server 2022 AlwaysOn新特性之包含可用性组详解 2023-07-29
- SQLSERVER调用C#的代码实现 2023-07-29
- 在阿里云CentOS 6.8上安装Redis 2023-09-12
- 搭建单机Redis缓存服务的实现 2023-07-13
- MySQL8.0.28安装教程详细图解(windows 64位) 2023-07-26
- Oracle 删除大量表记录操作分析总结 2023-07-23
- Mongodb启动报错完美解决方案:about to fork child process,waiting until server is ready for connections. 2023-07-16