i have found, simple queries,
session s = sessionfactory.getcurrentsession(); list<mod> list = s.createquery("from mod m m.modnameshort=:modname") .setparameter("modname", modname) .setcacheable(true) .list();
are cached well.
but cache not working one-to-many selections, this:
list<modversion> list = s.createquery("select m.modsversionses mod m") .setcacheable(true) .list();
it still makes requests db on second , next calls.
i have
props.setproperty("hibernate.cache.provider_class", "org.hibernate.cache.ehcacheprovider"); props.setproperty("hibernate.cache.region.factory_class", "org.hibernate.cache.ehcache.ehcacheregionfactory"); props.setproperty("hibernate.cache.use_second_level_cache", "true"); props.setproperty("hibernate.cache.use_query_cache", "true"); factorybean.sethibernateproperties(props);
, , mod object looks like
@entity @table(name = "mods", catalog = "artfunpw") @cache(usage = cacheconcurrencystrategy.transactional) public class mod implements java.io.serializable { *** @onetomany(fetch = fetchtype.lazy, mappedby = "mods") @orderby("releasedate desc") public set<modversion> getmodsversionses() { return this.modsversionses; } ***
the modversion object looks like
@entity @table(name = "mods_versions", catalog = "artfunpw", uniqueconstraints = @uniqueconstraint(columnnames = "versionnumber")) @cache(usage = cacheconcurrencystrategy.transactional) public class modversion implements java.io.serializable {
how enable caching such one-to-many queries?
thank you!
possible, question duplicate.
i found answer here using hibernate 2nd level cache or query cache lazy fetch queries , http://docs.jboss.org/hibernate/core/3.6/reference/en-us/html_single/#performance-cache-mapping
i should add @cache(usage = cacheconcurrencystrategy.read_write)
:
@onetomany(fetch = fetchtype.lazy, mappedby = "mods", cascade = {cascadetype.all}) @orderby("releasedate desc") @cache(usage = cacheconcurrencystrategy.read_write) public set<modversion> getmodsversionses() { return this.modsversionses; }
Comments
Post a Comment