参考代码如下:
String tbname = "login"
//获取mysql表主键值--redis启动时
long id = MySQL.getID(tbname)
//设置redis主键值--redis启动时
redisService.set(tbname, String.valueOf(id))
System.out.println(id)
long l = redisService.incr(tbname)
System.out.println(l)
Login login = new Login()
login.setId(l)
login.setName("redis")
redisService.hmset(String.valueOf(login.getId()), login)
boolean b = MySQL.insert("insert into login(id,name) values(" + login.getId()
+ ",'" + login.getName() + "')")
/**
*
* 队列处理器更新mysql失败:
*
* 清除缓存数据,同时主键值自减
*/
if (!b)
{
redisService.delKeyAndDecr
(tbname, "Login:"+String.valueOf(login.getId()))
// redisService.delete("Login:"+String.valueOf(login.getId()))
//redisService.decr(tbname)
}
System.out.println(redisService.exists("Login:"+String.valueOf(login.getId())))
System.out.println(redisService.get(tbname))
1:读取数据的时候先从redis里面查,若没有,再去数据库查,同时写到redis里面,并且要设置失效时间。 2:存数据的时候要具体情况具体分析,可以选择同时插到数据库和redis(要是存放到redis中,最好设置失效时间),也可以选择直接插到数据库里面,少考虑一些问题。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)