NHibernate,二级缓存不能与IQuery一起使用

时间:2011-12-02 16:30:50

标签: nhibernate

我正在使用二级缓存,我正在使用 默认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();
                }
            }

0 个答案:

没有答案