Pregunta

Necesito un cambio para el siguiente tipo de datos de clase asumido por defecto FluentNHibernate Automapping

public class plaparte
{
public virtual int id { get; private set; }
public virtual int vivos { get; set; }
public virtual int lesionados { get; set; }
public virtual int quemados { get; set; }
public virtual int muertos { get; set; }
public virtual int otros { get; set; }
public virtual string colaboracion { get; set; }
public virtual decimal hectareas { get; set; }
public virtual string reconocimiento { get; set; }
public virtual string disposiciones { get; set; }
public virtual plaserv plaserv { get; set; }
}
}

Necesito para esta clase solo el tipo de cadena para convertir a TEXTO en la base de datos Si cambio por

public virtual string[] reconocimiento { get; set; }

FluentNHibernate toma un tipo de datos BLOB

¿Puedo hacer algo como?

public class plaparteMappingOverride : IAutoMappingOverride<plaparte>
{
public void Override(AutoMapping<plaparte> mapping)
{
  Map(x => x.disposiciones).CustomSqlTypeIs("TEXT");
}
}
¿Fue útil?

Solución

Para resolver el problema que estoy usando:

using System.ComponentModel.DataAnnotations;
...
public class plaparte
{
...
[StringLength(4000)]
public virtual string disposiciones { get; set; }

Para crear campos de TEXTO

[Actualización]

Para trabajar, necesito crear la próxima clase

class StringLengthConvention : AttributePropertyConvention<StringLengthAttribute>
{
    protected override void Apply(StringLengthAttribute attribute, IPropertyInstance instance)
    {
        instance.Length(attribute.MaximumLength);
    }
}

también es necesario agregar la convención Fluent automap Me gusta

    static AutoPersistenceModel CreateAutomappings()
    {
        return AutoMap.AssemblyOf<plaparte>(new mapAutomapConfiguration())
            .Conventions.Setup(c =>
            {
                c.Add<StringLengthConvention>();
            });
    }
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top