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)类型?
感谢您的想法。当我尝试这样做时,出现一个新的异常: NHibernate.MappingException:无法实例化IType CharType:System.MissingMethodException:没有为此对象定义的无参数构造函数。 这发生在我建立我的SessionFactory的行上。 SessionFactory = configuration.BuildSessionFactory(); 想法? – ddc0660 2009-09-24 14:29:50
@ ddc0660 - 地图(x => x.Code).CustomSqlType(“char(1)”)适用于我。由于使用了一个字符串,这不是一个好的解决方案,但它起作用。 – Jurij 2013-11-20 19:43:45