hibernate memcached 二级缓存无效

我用memcached配置的二级缓存
Spring-hibernate配置:
[code="java"]


true
${hibernate.dialect}
${hibernate.show_sql}
${hibernate.format_sql}
${hibernate.cache.region_prefix}
true
true
${hibernate.cache.provider_class}
${hibernate.cache.use_structured_entries}
${hibernate.memcached.servers}
${hibernate.memcached.memcacheClientFactory}


[/code]

系统启动提示 Starting MemcachedClient...

要缓存的类映射文件里加了

而且我debug发现对象已经加载到memcached中了
[code="java"]
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:304
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:303
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:302
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:301
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:299
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:413
quality.cache.memcache.com.akazam.directview.develop.model.Application:0:121
.............
[/code]
但是我在测试调用的时候,仍然是去数据库查询的,而不是直接从缓存中读取
郁闷了,不知道是怎么回事
测试代码:
[code="java"]
List applications = null;
//getApi().getDao()返回一个HibernateGenericDao
applications = (List)getApi().getDao().loadAll(Application.class);
applications = (List)getApi().getDao().getList(" from Application ", new Object[]{});
applications = (List) getApi().getDao().loadAsHql(" from Application ");
applications = (List) getApi().getDao().loadAsHql(" from Application ");
[/code]
控制台输出了四条mysql查询语句,根本没有调用缓存
求大神帮忙看看哪出问题了!

1个回答

[code="java"]
你查询的结果有没有放置到缓存里面去
query.setCacheable(true)
[/code]

sfw0807
sfw0807 但我还是不明白,memcached里面已经有数据了呀,为什么还要再在查询的时候缓存?
接近 6 年之前 回复
sfw0807
sfw0807 我试了一下,你说的是对的,加了query.setCacheable(true)就可以了,谢谢!
接近 6 年之前 回复
sfw0807
sfw0807 我在调用查询之前去遍历了memcached缓存,里面已经缓存了数据呀
接近 6 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问