Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/297.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# SQL到Linq的转换——甚至可能吗_C#_Linq - Fatal编程技术网

C# SQL到Linq的转换——甚至可能吗

C# SQL到Linq的转换——甚至可能吗,c#,linq,C#,Linq,我有一个SQL查询,如下所示,我正在努力将其转换为等效的Linq SELECT * FROM Product A WHERE NOT EXISTS ( SELECT * FROM Vendors B JOIN ThirdPartyProduct C ON B.ProductId = C.ExternalProductId WHERE A.ProductCode = C.PrdouctCode AND C.SupportCode ) 我知道我可以使用Any来执行查询

我有一个SQL查询,如下所示,我正在努力将其转换为等效的Linq

SELECT * 
FROM Product A
WHERE NOT EXISTS
(
    SELECT * FROM Vendors B JOIN ThirdPartyProduct C 
    ON B.ProductId = C.ExternalProductId 
    WHERE A.ProductCode = C.PrdouctCode AND C.SupportCode
)

我知道我可以使用Any来执行查询中不存在的部分,但是,由于我也有一个连接,我不知道如何在Linq中计算它。非常感谢这里的任何帮助。

LINQ还支持内联子查询,因此转换基本上可以是一对一的-只有典型的LINQ
select
最后一个,在子查询之后无参数。换句话说,SQL
不存在(子查询)
转换为LINQ
!(子查询).Any()

大概是这样的:

from a in db.Product
where !(from b in db.Vendors
        join c in db.ThirdPartyProduct
        on b.ProductId equals c.ExternalProductId
        where a.ProductCode == c.ProductCode && c.SupportCode
        select b).Any()
select a;

LINQ还支持内联子查询,因此转换基本上可以是一对一的-只是典型的LINQ
select
最后一个,并且在子查询之后是无参数的。换句话说,SQL
不存在(子查询)
转换为LINQ
!(子查询).Any()

大概是这样的:

from a in db.Product
where !(from b in db.Vendors
        join c in db.ThirdPartyProduct
        on b.ProductId equals c.ExternalProductId
        where a.ProductCode == c.ProductCode && c.SupportCode
        select b).Any()
select a;

这是可能的,但您应该在尝试实现LINQ查询的地方包括您的安排(模型等)和代码。这是可能的,但您应该在尝试实现LINQ查询的地方包括您的安排(模型等)和代码。