休眠清除特定区域的缓存



我正在尝试手动清除特定区域的二级缓存。我找到了回答这个问题的方法。虽然这可以清除我的实体,但由于某种原因,查询缓存未被清除。这会导致下次从数据库中检索实体时对每个实体进行单独的查询。如果我在没有任何参数的情况下调用sessionFactory.EvictQueries((时确实有效。仅当我传入特定区域名称时,它才不起作用。关于出了什么问题的任何想法?

代码来自上面的链接:

private void ClearRegion(string regionName)
    {
        _sessionFactory.EvictQueries(regionName);
        foreach (var collectionMetaData in _sessionFactory.GetAllCollectionMetadata().Values)
        {
            var collectionPersister = collectionMetaData as NHibernate.Persister.Collection.ICollectionPersister;
            if (collectionPersister != null)
            {
                if ((collectionPersister.Cache != null) && (collectionPersister.Cache.RegionName == regionName))
                {
                    _sessionFactory.EvictCollection(collectionPersister.Role);
                }
            }
        }
        foreach (var classMetaData in _sessionFactory.GetAllClassMetadata().Values)
        {
            var entityPersister = classMetaData as NHibernate.Persister.Entity.IEntityPersister;
            if (entityPersister != null)
            {
                if ((entityPersister.Cache != null) && (entityPersister.Cache.RegionName == regionName))
                {
                    _sessionFactory.EvictEntity(entityPersister.EntityName);
                }
            }
        }
    }

缓存正在使用 NHProfiler 进行验证。

好的,所以我解决了我的问题。我没有意识到除了在实体映射中指定缓存区域之外,在查询数据时还需要指定缓存区域。将.CacheRegion("regionName")添加到我的查询后,一切正常。由于在查询时不添加区域,它将进入没有区域名称的查询缓存。这就是为什么当我在没有区域名称参数的情况下调用.EvictQueries()时它起作用的原因。

综上所述,有必要在映射实体时(.Region("regionName")在使用 Fluent 时(和使用 .CacheRegion("regionName") 查询 isession 时添加区域名称。

感谢您的回复。

最新更新