实体框架ISNULL在Where条件下

Usm*_*lid 4 .net c# entity-framework isnull

我在SQL Server中有一个查询:

SELECT * FROM MyTable t
WHERE ISNULL(t.Status,'') = ''
Run Code Online (Sandbox Code Playgroud)

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

编辑:哦对不起,我的代码就像

WHERE ISNULL(t.Status,'') = ''
Run Code Online (Sandbox Code Playgroud)

TJ *_*sky 16

尝试类似的东西

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

  • 这绝对不是更好的做法。它可以将高效的查找转换为全表扫描。不幸的是,[代码分析规则 SR0007](http://stackoverflow.com/a/7471822/73226) 确实(或至少)推荐了它,这可能就是 OP 拥有它的原因。 (2认同)

Sil*_*ind 6

虽然问题还可以,但逻辑并不合理.因为如果一个值等于CO,它就永远不会等于NULL或者''.在这种情况下,您可以轻松地像这样调用它:

SQL:

SELECT * FROM MyTable t
WHERE t.Status = 'CO'
Run Code Online (Sandbox Code Playgroud)

LINQ:

var items = (from t in db.MyTable
             where t.Status == "CO"
             select t);
Run Code Online (Sandbox Code Playgroud)

但是,如果您需要它在NULL与该值比较时具有默认值,那么它将更有意义(参见示例):

SQL:

SELECT * FROM MyTable t
WHERE ISNULL(t.Status, 'CO') = 'CO'
Run Code Online (Sandbox Code Playgroud)

LINQ:

var items = (from t in db.MyTable
             where (t.Status ?? "CO") == "CO"
             select t);
Run Code Online (Sandbox Code Playgroud)

这将为您提供t.Status NULL等于或等于的所有项目CO.当然,这只是一个例子.

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

SELECT * FROM MyTable t
WHERE COALESCE(t.Status, 'CO') = 'CO'
Run Code Online (Sandbox Code Playgroud)