public Long querySumJe() { String sJe = redisDao.getValue("sumje"); if(!"null".equalsIgnoreCase(sJe) && sJe != null){ System.out.println("==========cache"); return Long.parseLong(sJe); }else{ synchronized (this) { sJe = redisDao.getValue("sumje"); if(!"null".equalsIgnoreCase(sJe) && sJe != null){ System.out.println("==========cache2"); return Long.parseLong(sJe); } System.out.println("==========db"); Long je = chjlmxbMapper.querySumJe(); redisDao.putValue("sumje", je+""); return je; } } }
注意:通常的在锁里面不会再查询缓存了,这样就同样会形成缓存击穿,因此在锁中查询数据库前再查询一次缓存是必要的,须要注意。redis