EF4 CodeFirst CTP5 nvarchar(max)via属性

时间:2011-02-22 20:19:43

标签: entity-framework-4 data-annotations ef4-code-only fluent-interface code-first

有没有办法创建自定义属性,使EF CodeFirst在分配给poco类的属性时使用 nvarchar(max)作为数据类型?我知道这可以通过流畅的api实现,但我们希望将所有定义放在一个地方,这就是元数据类。

Fluent API:

modelBuilder.Entity<Event>().Property(p => p.TicketText).HasColumnType("nvarchar(max)");

2 个答案:

答案 0 :(得分:7)

public class NVarcharMaxAttribute : Attribute { }

public class NVarcharMaxAttributeConvention : AttributeConfigurationConvention<PropertyInfo, StringPropertyConfiguration, NVarcharMaxAttribute> {
    public override void Apply(PropertyInfo memberInfo, StringPropertyConfiguration configuration, NVarcharMaxAttribute attribute) {
        configuration.ColumnType = "nvarchar(max)";
    }
}

protected override void OnModelCreating(ModelBuilder modelBuilder) {
    modelBuilder.Conventions.Add<NVarcharMaxAttributeConvention>();
}

答案 1 :(得分:5)

[System.ComponentModel.DataAnnotations.MaxLength]