方法一:直接用Mysql
Mysql有缓存,实现了类似的功能,如果需要缓存的东西很多,可以把缓存的内存设置大一点。
这样的好处就是不用去控制缓存的失效,确保数据一致性。

方法二:启用用DAO框架的缓存
比如Mybatis、Hibernate都是可以直接开启二级缓存,一般是用ehcache作为实现,只要配置一下就行,无需额外操作。

方法三:自行实现
用AOP去在Dao层做一个切面,把调用的“类名+方法名+参数”作为key,查询结果作为value,每次调用去看一下是否已经缓存,如果没有再去调用Dao的实现类。
注:如果真的要自行去实现,不建议做一个这么通用的方案,感觉重复造轮子。对性能要求极高的场景,可以根据实际需要做一些必要的缓存即可。

http://zhidao.baidu.com/link?url=KmnyEV_emBwZNK2LOrPxLlO59HV8DhrgRkfkJYlkRYZpTLpqctYafQiZxq8VPpiVCJgtuURjgjTRC8RSvc7xqS20zSdipZSONVuAOxhVhYG

05-28 12:29