实体框架在Where条件下为ISNULL

问题描述 投票:0回答:2

我在 SQL Server 中有一个查询:

SELECT * FROM MyTable t
WHERE ISNULL(t.Status,'') = ''

我如何在实体框架中做到这一点?

c# .net entity-framework isnull
2个回答
27
投票

尝试类似的事情

MyTable.Where( t => (t.Status ?? "") == "CO" )


6
投票

虽然问题没问题,但逻辑不通。 因为如果一个值等于

CO
,它永远不可能等于
NULL
''
。 在这种情况下,您可以轻松地这样调用它:

SQL:

SELECT * FROM MyTable t
WHERE t.Status = 'CO'

林克:

var items = (from t in db.MyTable
             where t.Status == "CO"
             select t);

但是,如果您需要它在

NULL
时具有默认值并与该值进行比较,则会更有意义(参见示例):

SQL:

SELECT * FROM MyTable t
WHERE ISNULL(t.Status, 'CO') = 'CO'

林克:

var items = (from t in db.MyTable
             where (t.Status ?? "CO") == "CO"
             select t);

这将为您提供 t.Status 为

NULL
或等于
CO
的所有项目。 当然,这只是一个例子。

注意:生成的sql可能会略有不同,但结果是相同的。 它可能看起来像这样:

SELECT * FROM MyTable t
WHERE COALESCE(t.Status, 'CO') = 'CO'
© www.soinside.com 2019 - 2024. All rights reserved.