问题描述
|
我有以下查询:
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,问题应该消失了。