我已经在会话工厂上配置了二级缓存。但是对于 POCO 实体,我没有启用缓存。
我正在使用 Fluent NHibernate 来配置 SessionFactory 和 POCO 实体。
这是会话工厂的配置:
var cfg = Fluently.Configure()
.Database(MsSqlConfiguration.MsSql2008.ConnectionString(connectionString)
.Provider("NHibernate.Connection.DriverConnectionProvider, NHibernate")
.Dialect<CustomMsSql2008Dialect>()
.Driver<SqlAzureClientDriver>()
.ShowSql())
.Cache(x =>
{
x.UseQueryCache();
x.UseSecondLevelCache().ProviderClass<HashtableCacheProvider>().UseMinimalPuts();
})
POCO实体配置如下:
public CustomerConfiguration()
{
Table("Sys_Customer");
DynamicUpdate();
Id(x => x.Id).GeneratedBy.GuidComb().UnsavedValue(Guid.Empty);
Map(x => x.Code);
Map(x => x.Name);
Map(x => x.IsActive);
Component(x => x.Contact).ColumnPrefix("Contact_");
Component(x => x.Address).ColumnPrefix("Address_");
Map(x => x.IsDeleted);
Map(x => x.CreatedOn).Column("CreatedOn");
Map(x => x.CreatedBy).Column("CreatedBy").Length(100);
Map(x => x.LastModifiedOn).Column("LastModifiedOn");
Map(x => x.LastModifiedBy).Column("LastModifiedBy").Length(100);
Version(x => x.RowVersion).UnsavedValue("0");
}
很明显,对于 Sys_Customer 实体,我没有配置任何缓存,但是当我运行以下代码时:数据库只被命中一次:
using (ISession s = RepositorySession)
{
var f = s.Get<Customer>(new Guid("75EDC0C2-4E58-43FF-B0D8-8C52FBB2D502"));
var d = f.Code;
}
using (ISession s = RepositorySession)
{
var f = s.Get<Customer>(new Guid("75EDC0C2-4E58-43FF-B0D8-8C52FBB2D502"));
var d = f.Code;
}
当我从 SessionFactory 中删除缓存配置时,数据库会被命中两次。很明显,实体被缓存在二级缓存中。
有人可以告诉我如何避免将实体缓存到 NHibernate 的二级缓存中????