c# - Entity Framework - 查询可为空列的问题

标签 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)

那么,为什么 Entity Framework 会在这里生成不正确的查询,有什么办法可以解决这个问题吗?

谢谢,

汤姆

最佳答案

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

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

关于c# - Entity Framework - 查询可为空列的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3205238/

相关文章:

entity-framework - Entity Framework 设计器不会添加表

加入时MySQL语法错误

sql - 如何使用变量作为表名检查表是否存在

sql - postgresql 两个嵌套连接和连接中的数组

c# - 我可以直接使用 Entity Framework 生成的模型吗?

c# - Entity Framework Core InMemory 数据库测试在并行运行时会中断

entity-framework - 列名无效

c# - ASP.NET MVC 3.0 中的状态模式

c# - 如何使 NLog 在运行时线程安全地写入单独的文件目标?

c# - 在 Microsoft Visual Studio 2013 的 WinForms 中启用 Entity Framework 6 for MySql (C#)