如何解决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,问题应该消失了。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。