【问题标题】:Entity Framework - Problem with querying nullable column实体框架 - 查询可空列的问题
【发布时间】:2010-07-08 15:27:33
【问题描述】:

我在从具有可为空的 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)

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

谢谢,

汤姆

【问题讨论】:

  • 谢谢,是的,这确实有帮助,尽管它是针对 linq to sql 而不是实体框架(object.Equals 在实体框架中不起作用),我不得不求助于这段讨厌的代码:( positionEffect == null ? x.PositionEffect == null : x.PositionEffect == (byte?)positionEffect)

标签: c# sql entity-framework


【解决方案1】:

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

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

【讨论】:

    猜你喜欢
    • 2011-03-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-12-27
    相关资源
    最近更新 更多