我有以下约定,我加载到我的FNH配置
public class TableNameConvention : IClassConvention, IClassConventionAcceptance
{
public void Accept(IAcceptanceCriteria<IClassInspector> criteria)
{
criteria.Expect(x => x.TableName, Is.Not.Set);
}
public void Apply(IClassInstance instance)
{
var tableName = instance.EntityType.Name.Pluralise();
instance.Table(tableName);
}
}
我没有在我的映射的任何上指定表名,但是没有应用此约定。我正在使用Fluent NHibernate 1.4.1.1。任何人都可以发现我可能做错的事吗?
更新
约定按以下方式加载:
public static NHibernate.Cfg.Configuration BuildConfiguration()
{
var connectionStringName = "mydb";
return Fluently.Configure(new NHibernate.Cfg.Configuration())
.Database(MsSqlConfiguration
.MsSql2008.ConnectionString(c => c.FromConnectionStringWithKey(connectionStringName))
.Dialect<MsSql2008Dialect>()
.AdoNetBatchSize(50))
.Mappings(m =>
{
m.FluentMappings.AddFromAssemblyOf<Profile>();
m.FluentMappings.Conventions.Add(DefaultLazy.Always(), DynamicUpdate.AlwaysTrue(), DynamicInsert.AlwaysTrue());
m.FluentMappings.Conventions.AddFromAssemblyOf<HiLoConvention>();
})
.ExposeConfiguration(config => config.SetProperty(NHibernate.Cfg.Environment.CurrentSessionContextClass, typeof(ManagedWebSessionContext).AssemblyQualifiedName))
.ExposeConfiguration(HiLoConvention.CreateScript)
.ExposeConfiguration(RunSchemaUpdate)
.BuildConfiguration();
}
所有约定与上面在.AddFromAssembly()方法调用中引用的HiLoConvention位于相同的程序集和命名空间中。
更新2:
问题出在Accept()方法中,因为如果我删除此方法(以及类声明中的IClassConventionAcceptance接口),则应用约定。我也试过这个期望无济于事
criteria.Expect(x => string.IsNullOrEmpty(x.TableName))
原始代码适用于Fluent 1.2.1 ...
答案 0 :(得分:0)
你试过吗
m.FluentMappings.ConventionDiscovery.AddFromAssemblyOf<HiLoConvention>()
取代
m.FluentMappings.Conventions.AddFromAssemblyOf<HiLoConvention>()
答案 1 :(得分:0)
这个问题很老,但也许这可以帮助其他人:
我假设你想在每个实体上设置约定,除非在地图中明确指定了表名。因此,要实现这一目标,您只需执行以下操作:
public class TableNameConvention : IClassConvention
{
public void Apply(IClassInstance instance)
{
var tableName = instance.EntityType.Name.Pluralise();
instance.Table(tableName);
}
}
这将在所有实体上应用约定,除非在地图中明确指定了TableName。