流畅的nHibernate - 查询缓存无法使用“session.Query”和Cacheable()

时间:2012-11-04 16:22:29

标签: nhibernate caching fluent

没有得到任何QueryCacheHitCount。源代码如下: nHibernate 3.3.1.4000,FluentnHibernate 1.3.0.733

配置:

Factory = Fluently.Configure()
    .ExposeConfiguration(c =>
        c.SetProperty(NHibernate.Cfg.Environment.GenerateStatistics, "true"))
    .Database(
    MsSqlConfiguration.MsSql2008.ConnectionString(c => c.Is("DATA SOURCE=localhost;PERSIST SECURITY INFO=True;USER ID=AAA;Password=AAA"))
            .ShowSql()
    )
    .Mappings(x => x.FluentMappings.AddFromAssemblyOf<Localization.NHibernate.Article>())
    .ExposeConfiguration(BuildDatabase)
    .Cache(
        x => x.UseSecondLevelCache()
                .UseQueryCache()                         
                .ProviderClass<NHibernate.Cache.HashtableCacheProvider>())
    .BuildSessionFactory();

执行:

using (var tx = session.BeginTransaction())
{
    Factory.Statistics.Clear();

    for (int i = 0; i < 10; i++)
    {
        Article s = session.Query<Article>().Cacheable().Where(x => x.Name == "O").SingleOrDefault();
    }

    Console.WriteLine(Factory.Statistics.QueryCacheHitCount);
    Console.WriteLine(Factory.Statistics.SecondLevelCacheHitCount);
    Console.WriteLine(Factory.Statistics.QueryExecutionCount);
}

仅当我更改缓存配置并添加我的私有QueryCacheFactory .QueryCacheFactory<CacheFactory>()而不是它的工作时(但我忽略了IsUpToDate检查)

public class CacheFactory : NHibernate.Cache.IQueryCacheFactory
{
    public NHibernate.Cache.IQueryCache GetQueryCache(string regionName, NHibernate.Cache.UpdateTimestampsCache updateTimestampsCache, Settings settings, IDictionary<string, string> props)
    {
        return new MyStandardQueryCache(settings, props, updateTimestampsCache, regionName);
    }

    private class MyStandardQueryCache : NHibernate.Cache.StandardQueryCache
    {
        public MyStandardQueryCache(Settings settings, IDictionary<string, string> props, NHibernate.Cache.UpdateTimestampsCache updateTimestampsCache, string regionName)
            : base(settings, props, updateTimestampsCache, regionName) { }

        protected override bool IsUpToDate(Iesi.Collections.Generic.ISet<string> spaces, long timestamp)
        {
            return true; // SET TO TRUE than it's hitting the cache
        }
    }
}

1 个答案:

答案 0 :(得分:0)

我遇到了类似的问题,而且我记得,查询的结果是使用会话的创建时间或事务来缓存的。尝试使用会话进行第一次查询,使用不同的会话进行以下操作,这样做就可以接收缓存命中。