我正在使用二级缓存,我正在使用 默认Hashtable因为我只是在测试这个功能。 我已按以下方式配置了hibernate.cfg.xml:
<property
name="cache.provider_class">NHibernate.Cache.HashtableCacheProvider</
property>
<!-- You have to explicitly enable the second level cache -->
<property name="cache.use_second_level_cache">true</property>
<!-- cache will expire in 2 minutes -->
<property name="cache.default_expiration">120</property>
<!-- I want also to cache queries -->
<property name="cache.use_query_cache">true</property>
我已按以下方式将我的实体配置为可缓存:
<class
name="CachableProduct"
table="[CachableProduct]"
dynamic-insert="true"
dynamic-update="true">
<cache usage="read-write"/>
<id name="ProductId">
<generator class="guid.comb" />
</id>
<property name="Name">
</property>
<property name="Price">
</property>
</class>
当我尝试运行以下单元测试时,它总是打印出两个 SELECT语句,所以它显然不会缓存实体。但如果我 写一个单元测试调用Load或Get来自两个不同的 会话,二级缓存工作,所以我相信我有一个问题 使用查询缓存。
using (var session = factory.OpenSession())
{
using (var tx =
session.BeginTransaction(IsolationLevel.ReadCommitted))
{
Console.WriteLine("*** FIRST SESSION ***");
var result = session
.CreateCriteria(typeof(CachableProduct))
.SetCacheable(true)
.Add(Restrictions.Eq("Name", "PC"))
.List<CachableProduct>();
tx.Commit();
}
}
using (var session = factory.OpenSession())
{
using (var tx =
session.BeginTransaction(IsolationLevel.ReadCommitted))
{
Console.WriteLine("*** SECOND SESSION ***");
var result = session
.CreateCriteria(typeof(CachableProduct))
.SetCacheable(true)
.Add(Restrictions.Eq("Name", "PC"))
.List<CachableProduct>();
tx.Commit();
}
}