实体框架 - 查询可空列的问题

时间:2010-07-08 15:27:34

标签: c# sql entity-framework

我在查询具有可空的tinyint列的表中的数据时遇到问题 问题似乎是查询生成为:

AND ( CAST( [Extent1].[PositionEffect] AS int) = @p__linq__3)

=> @ p__linq__3 = NULL

如果我手动运行该查询,则不会显示任何结果。但是,当我用:

替换查询时
AND ([Extent1].[PositionEffect] IS @p__linq__3)

它显示了预期的结果 我的C#查询如下所示:

 context.Allocations.Where(x => ... && x.PositionEffect == (byte?) positionEffect)

那么,为什么实体框架在这里生成了错误的查询,有没有办法解决这个问题?

谢谢,

汤姆

1 个答案:

答案 0 :(得分:1)

正如Will A所指出的,这似乎是实体框架中报告的错误,生成正确查询的解决方法是:

 (positionEffect == null ? x.PositionEffect == null : x.PositionEffect == (byte?)positionEffect)