使用Fluent nHibernate将SQL Server时间戳列自动映射到byte []

时间:2010-08-12 16:41:35

标签: sql-server fluent-nhibernate

我开始在项目上使用Fluent nHibernate,并且我正在尝试使自动化工作。当时我坚持将数据库的时间戳字段映射到字节数组。我们使用SQL Server 2008作为数据库,我们不是从代码生成数据库。

我有什么:

public class Entity
  {
        public virtual Guid RowID { get; protected set; }
        public virtual byte[] ChangeCheck { get; protected set; }
        public virtual string Data { get; set; }
  }

我们的数据库约定是将版本字段命名为“ChangeCheck”。我无法找到我覆盖DefaultAutomappingConfiguration默认行为的位置,以使用ChangeCheck作为自动生成的版本字段。

是否可以使用DefaultAutomappingConfiguration子类将所有ChangeCheck字段自动化为版本字段?

感谢您的任何指示和帮助。

可选解决方案:

鉴于我使用'ChangeCheck'为所有实体创建了一个自动覆盖,我可以执行以下操作:

 private class ChangeCheckVersionConvention : IVersionConvention
    {
        public void Apply(IVersionInstance instance)
        {
            instance.Column("ChangeCheck");
            instance.Generated.Always();
            instance.UnsavedValue(null);
        }
    }

public class EntityOverride : IAutoMappingOverride<IssueReport>
    {
        public void Override(AutoMapping<IssueReport> mapping)
        {
            mapping.Version(m => m.ChangeCheck);
        }
     }

 //....
 var persistenceModel = AutoMap.AssemblyOf<MyConfiguration>(new MyConfiguration())
            .UseOverridesFromAssemblyOf<MyConfiguration>()
            .Conventions.Add<ChangeCheckVersionConvention>();

哪个有效,但我无法弄清楚如何删除覆盖以将ChangeCheck列设置为我的版本列,而不必覆盖我的所有实体。

1 个答案:

答案 0 :(得分:2)

在没有到达任何地方后,我决定逐步完成Fluent nHibernate代码,看看发生了什么。然后我找到了如何设置'DefaultAutomappingConfiguration'并创建了我自己的版本:

public class MyAutomappingStoreConfiguration : DefaultAutomappingConfiguration
{
    public override IEnumerable<IAutomappingStep> GetMappingSteps(AutoMapper mapper, IConventionFinder conventionFinder)
    {
        return new IAutomappingStep[]
        {
            new IdentityStep(this),
            new MyChangeCheckVersionStep(this),
            new ComponentStep(this, mapper),
            new PropertyStep(conventionFinder, this),
            new HasManyToManyStep(this),
            new ReferenceStep(this),
            new HasManyStep(this)
        };
    }
}

请注意 MyChangeCheckVersionStep ,这是不同的。然后我实现了一个 VersionStep 类,它将 ChangeCheck 添加到假定为Version列的列名列表中:

public class MyChangeCheckVersionStep: IAutomappingStep
{
    private static readonly IList<string> validNames 
         = new List<string> { "version", "timestamp", "changecheck" };
    private static readonly IList<Type> validTypes
         = new List<Type> { typeof(int), typeof(long), typeof(TimeSpan), typeof(byte[]) };

    private readonly IAutomappingStep defaultVersionStep;

    public MyChangeCheckVersionStep(IAutomappingConfiguration cfg)
    {
        this.defaultVersionStep = new VersionStep(cfg);
    }

    public bool ShouldMap(Member member)
    {
        return validNames.Contains(member.Name.ToLowerInvariant())
           && validTypes.Contains(member.PropertyType);
    }

    public void Map(ClassMappingBase classMap, Member member)
    {
        defaultVersionStep.Map(classMap, member);
    }
}

除了 ShouldMap 之外,该类基本上会调用defualt VersionStep 实现。

现在我不再需要为每个实体创建覆盖以使版本正常工作。另请注意,我仍然使用 ChangeCheckVersionConvention - 它是我不再需要的每个实体类的覆盖。