1

La carte.fluent nhibernate problème cartographie char (1) type

public SocialCodeMap() 
    { 
     Id(x => x.SocialCodeId); 
     Map(x => x.Name); 
     Map(x => x.Code); 
     Map(x => x.DisplayOrder); 
    } 

Et la classe.

public class SocialCode 
{ 
    public virtual Guid SocialCodeId { get; set; } 
    public virtual string Name { get; set; } 
    public virtual char Code { get; set; } 
    public virtual int DisplayOrder { get; set; } 
} 

Et l'appel.

public SocialCode FetchByCode(char code) 
    { 
     return Session.CreateCriteria<SocialCode>().Add<SocialCode>(x => x.Code == code).UniqueResult<SocialCode>(); 
    } 

Je reçois cette erreur lors de l'exécution de FetchByCode().

System.Exception: Cannot convert '65' to System.Char 
at NHibernate.LambdaExtensions.ExpressionProcessor.ConvertType(Object value, Type type) 
at NHibernate.LambdaExtensions.ExpressionProcessor.ProcessSimpleExpression(BinaryExpression be) 
at NHibernate.LambdaExtensions.ExpressionProcessor.ProcessBinaryExpression(BinaryExpression expression) 
at NHibernate.LambdaExtensions.ExpressionProcessor.ProcessLambdaExpression(LambdaExpression expression) 
at NHibernate.LambdaExtensions.ExpressionProcessor.ProcessExpression<T>(Expression`1 expression) 
at NHibernate.LambdaExtensions.ICriteriaExtensions.Add<T>(ICriteria criteria, Expression`1 expression) 
at DAL.NHibernate.xxx.SocialCodeRepository.FetchByCode(Char code) in SocialCodeRepository.cs: line 18 
at UnitTests.DAL.xxx.yyy.SocialCodeRepositoryFixture.FetchByCode_ReturnsNullCodeDNE() in SocialCodeRepositoryFixture.cs: line 38 

Il semble que NHibernate converge mon char vers un int quelque part en cours de route. Comment puis-je le forcer à utiliser le type char (1) qui est sur la colonne?

Répondre

2

Je suppose que Fluent-NH peut détecter automatiquement le type de caractère correctement. Mais si cela ne peut pas, vous pouvez toujours montrer un indice. Essayez cette

Map(x => x.Code).CustomType<NHibernate.Type.CharType>(); 

Mise à jour:

Désolé que je ne l'ai pas testé le code. Eh bien, j'ai essayé et constaté que le bug est dans les extensions Lambda NH. En bref,

// mapping 
Map(x => x.Code); 

// querying 
criteria.Add(Restrictions.Eq("Code", 'A')); 

J'ai testé cela devrait fonctionner.

+2

Merci pour l'idée. Je reçois une nouvelle exception lorsque j'essaie ceci: NHibernate.MappingException: Impossible d'instancier IType CharType: System.MissingMethodException: Aucun constructeur sans paramètre défini pour cet objet. Cela se produit sur la ligne où je crée ma SessionFactory. SessionFactory = configuration.BuildSessionFactory(); Pensées? – ddc0660

+0

@ ddc0660 - Map (x => x.Code) .CustomSqlType ("char (1)") fonctionne pour moi. Pas une bonne solution en raison de l'utilisation d'une chaîne, mais cela fonctionne. – Jurij