5

环境: NHibernate 4.0.0.4000;NHibernate.Caches.SysCache 4.0.0.4000; Web MVC/API 4.5.1;FluentNHibernate 1.4.0.0;VS2013;

如您所见,我正在尝试在 nhibernate 上缓存 SQL 查询(无需缓存即可完美运行):

        return Session.CreateSQLQuery(sql)
            .AddScalar("Id", NHibernateUtil.Int32)
            .AddScalar("Summary", NHibernateUtil.String)
            .SetResultTransformer(Transformers.AliasToBean<ProductDto>())
            .SetCacheable(true)
            //.SetCacheRegion("Long") throws same error regardless of this
            .List<ProductDto>()
            ;

但它不断抛出 ArgumentNullException,请参阅详细信息:

Value cannot be null.
Parameter name: source
  at System.Linq.Enumerable.Count[TSource](IEnumerable`1 source, Func`2 predicate)
   at NHibernate.Util.ArrayHelper.CountTrue(Boolean[] array)
   at NHibernate.Transform.CacheableResultTransformer.Create
   ...

我尝试使用另一个缓存提供程序,即 NHibernate.Caches.RtMemoryCache,但错误是相同的。

调用后也没有记录休眠信息,因为错误显然发生在其管道的早期阶段。

缓存配置,使用 Fluent NHibernate:

 (OracleClientConfiguration.Oracle10.ConnectionString(connStr).AdoNetBatchSize(20000)).Cache(c => c.ProviderClass<SysCacheProvider>().UseSecondLevelCache().UseQueryCache())

有关缓存设置的日志信息(如果我使用区域,自然会更改):

INFO  2014-11-03 08:51:33,474 [1    ] NHibernate.Cache.StandardQueryCache      - starting query cache at region: NHibernate.Cache.StandardQueryCache

有任何想法吗?或者问题可能缺少信息?

谢谢!

4

0 回答 0