繁体   English   中英

实体框架将查询转换为空

[英]Entity Framework converting the query to is null

当我在 Management Studio 中运行= null时,它不返回任何行,但是当我运行is null我会返回数据。 在实体框架中,它正在将查询转换为空,有没有其他选择,所以我可以在实体框架中执行= null

这不返回任何行

SELECT *
FROM cart c
WHERE OrderId = NULL

这返回 1000 行

SELECT *
FROM cart c
WHERE OrderId IS NULL

EF 列表计数 1000 行

var Pending = (from c in db.Cart 
               where sc.OrderId == null
               select sc.CartId).ToList();

Null 表示未知值。 在 SQL 中,试图将任何值等同于 NULL 将导致 FALSE,这是有道理的。 因此,2 = NULL 为 FALSE。 NULL = NULL 为假。 但是,列 IS NULL 检查列的值是否为 NULL。

C# 的语义是不同的,当 EF 框架将查询发送到服务器时,最终会将您的查询转换为 IS NULL。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM