1

地圖。流利的nhibernate問題映射char(1)類型

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

And the Class。

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

並呼籲。

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

運行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 

看來NHibernate正在將我的char轉化爲int中的某個int。我如何強制它使用列上的char(1)類型?

回答

2

我假設Fluent-NH可以正確地自動檢測字符類型。但如果它不能,你可以隨時顯示提示。試試這個

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

更新:

對不起,我沒有測試的代碼。好吧,我試了一下,發現這個錯誤在NH Lambda Extensions中。總之,

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

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

我測試這應該工作。

+2

感謝您的想法。當我嘗試這樣做時,出現一個新的異常: NHibernate.MappingException:無法實例化IType CharType:System.MissingMethodException:沒有爲此對象定義的無參數構造函數。 這發生在我建立我的SessionFactory的行上。 SessionFactory = configuration.BuildSessionFactory(); 想法? – ddc0660 2009-09-24 14:29:50

+0

@ ddc0660 - 地圖(x => x.Code).CustomSqlType(「char(1)」)適用於我。由於使用了一個字符串,這不是一個好的解決方案,但它起作用。 – Jurij 2013-11-20 19:43:45