1

地図。

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

そしてクラス。

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 に変換しているようです。列にある char(1) 型を強制的に使用するにはどうすればよいですか?

4

1 に答える 1

2

Fluent-NH は自動的に char 型を正しく検出できると思います。しかし、それができない場合は、いつでもヒントを示すことができます。これを試して

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

アップデート:

コードをテストしていないことをお詫び申し上げます。さて、私が試してみたところ、バグは NH Lambda 拡張機能にあることがわかりました。要するに、

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

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

これが機能することをテストしました。

于 2009-09-23T12:52:34.373 に答える