1

我遇到了一个问题,Sharp Architecture 将正确映射我在IAutoMappingOverride课程中设置的所有内容,除了Formula. 这些被简单地忽略了,因此我invalid identifier在尝试查询数据库时得到了 SQL。

// NUnit setup
public virtual void SetUp()
{
    configuration = NHibernateSession.Init(
        new SimpleSessionStorage(),
        RepositoryTestsHelper.GetMappingAssemblies(),
        new AutoPersistenceModelGenerator().Generate(),
        null,
        null,
        null,
        FluentConfigurer.TestConfigurer.Contracts);

    new FluentConfigurer(configuration)
        .ConfigureNHibernateValidator()
        .ConfigureAuditListeners();
}


public AutoPersistenceModel Generate()
{
    return AutoMap.AssemblyOf<Contrato>(new AutomappingConfiguration())
        .Conventions.Setup(GetConventions())
        .IgnoreBase<Entity>()
        .IgnoreBase(typeof(EntityWithTypedId<>))
        .UseOverridesFromAssemblyOf<EmployeeMap>();
}

// My override.
public class EmployeeMap : IAutoMappingOverride<Employee>
{
    public void Override(AutoMapping<Employee> mapping)
    {
        // This works...
        mapping.Id(x => x.Id, "ID_EMPLOYEE");

        // This is ignored...
        mapping.Map(x => x.Name).Formula("UPPER(LTRIM(RTRIM(FIRST_NAME || ' ' || LAST_NAME)))");
    }
}

有任何想法吗?

4

2 回答 2

0

这不是 Sharp Architecture 的问题,而是 Fluent Nhibernate 的问题。您使用的是哪个版本的 FNH?

于 2011-05-16T03:06:24.583 回答
0

我确认这是Fluent NHibernate(1.2.0.694) 的问题。以前,列名映射将优先于 FluentMappingOverrides,但最新的将优先于约定。我修改了约定以排除包含公式映射的命名空间,现在可以了。

    public class OracleUnderscoredNamingConvention : IPropertyConvention 
    { 
        public void Apply(IPropertyInstance instance) 
        { 
            // Previously worked without this condition. 
            if 
(Utils.WorkableDomainNamespaces.Contains(instance.Property.PropertyType.Nam espace)) 
            { 
instance.Column(OracleConventionSetter.ApplyOracleNamingConventions(instanc e.Property.Name)); 
            } 
        } 
    } 
于 2011-05-16T04:06:25.490 回答