Question

J'ai besoin de modification pour le type de données de classe suivante supposée par défaut

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; }
}
}

J'ai besoin que cette classe ne soit que le type de chaîne à convertir en texte dans la base de données si je change par

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

FluentnHibernate prend un type de données blob

Je peux faire quelque chose comme?

public class plaparteMappingOverride : IAutoMappingOverride<plaparte>
{
public void Override(AutoMapping<plaparte> mapping)
{
  Map(x => x.disposiciones).CustomSqlTypeIs("TEXT");
}
}
Était-ce utile?

La solution

Pour résoudre le problème que j'utilise:

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

Pour créer des champs de texte

Mise à jour

Pour le travail, j'ai besoin de créer la prochaine classe

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

est également nécessaire pour ajouter la convention Automap

    static AutoPersistenceModel CreateAutomappings()
    {
        return AutoMap.AssemblyOf<plaparte>(new mapAutomapConfiguration())
            .Conventions.Setup(c =>
            {
                c.Add<StringLengthConvention>();
            });
    }
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top