Csharp/C#教程:entity frameworkISNULL在Where条件下分享


entity frameworkISNULL在Where条件下

我在SQL Server中有一个查询:

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

我如何在entity framework中做到这一点?

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

 WHERE ISNULL(t.Status,'') = '' 

尝试类似的东西

MyTable.Where(t =>(t.Status ??“”)==“CO”)

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

SQL:

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

LINQ:

 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' 

LINQ:

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

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

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

上述就是C#学习教程:entity frameworkISNULL在Where条件下分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

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

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/1031684.html

(0)
上一篇 2022年1月14日
下一篇 2022年1月14日

精彩推荐