代码: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使用代码
基础教程推荐
猜你喜欢
- 【Redis】数据持久化 2023-09-12
- Mysql查询所有表和字段信息的方法 2023-07-26
- Sql Server Management Studio连接Mysql的实现步骤 2023-07-29
- Redis如何实现延迟队列 2023-07-13
- Mysql主从三种复制模式(异步复制,半同步复制,组复 2022-09-01
- python中pandas库的iloc函数用法解析 2023-07-28
- 关于MySQL中explain工具的使用 2023-07-27
- SQLServer 清理日志的实现 2023-07-29
- Python常见库matplotlib学习笔记之多个子图绘图 2023-07-27
- 如何将excel表格数据导入postgresql数据库 2023-07-20