nHibernate无法将Boolean强制转换为String

问题描述

| 我有以下查询:
var query = from item in Session.Query<FactuurItem>()
    where item.EnergieType == etype
    && (item.DienstType == null || item.DienstType == DienstType.Onbekend || item.DienstType == dtype)
    && item.IsActive == true
    orderby item.Naam
    select item;
将其转换为以下SQL:
select * from [FactuurItem] factuurite0_ 
where 
    factuurite0_.EnergieType=? 
    and (factuurite0_.DienstType is null or factuurite0_.DienstType=? or factuurite0_.DienstType=?) 
    and case when factuurite0_.IsActive=1 then \'true\' else \'false\' end=case when ?=\'true\' then \'true\' else \'false\' end 
order by factuurite0_.Naam asc
导致异常:
{\"Unable to cast object of type \'System.Boolean\' to type \'System.String\'.\"}
现在我的问题是:为什么? 原始查询对我来说没问题。但是,SQL没有。这两个案例陈述从何而来?显然,它试图将属性IsActive转换为SQL中的字符串,但这样做失败。 编辑 好的,找到解决方案。映射等没有问题,只是LINQ查询如何转换为SQL。特别是,此行的翻译方式:
&& item.IsActive == true
不知何故,这被转换为复杂的CASE语句,最终导致异常消息。但是,the4ѭ部分并不是必需的。通过删除它,翻译器不再感到困惑,并提供了适当的SQL:
factuurite0_.IsActive=1
没有更多的案例陈述,也没有更多的例外。     

解决方法

好的,找到解决方案。映射等没有问题,只是LINQ查询如何转换为SQL。特别是,此行的翻译方式:
&& item.IsActive == true
不知何故,这被转换为复杂的CASE语句,最终导致异常消息。但是,the4ѭ部分并不是必需的。通过删除它,翻译器不再感到困惑,并提供了适当的SQL:
factuurite0_.IsActive=1
没有更多的案例陈述,也没有更多的例外。     ,在调试级别使用Log4Net?在某些版本的Hibernate和Log4Net中,在DEBUG级别打开日志记录时不兼容。您得到的只是关于“无法执行sql无法将布尔值转换为字符串”的错误。尝试将您的日志记录级别提高到INFO,问题应该消失了。     

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...