首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Linq2Sql中编写此查询

如何在Linq2Sql中编写此查询
EN

Stack Overflow用户
提问于 2010-05-11 03:52:41
回答 5查看 153关注 0票数 6

我有一个表公司持有的company_id,company_name和其他细节。我有一个表subcontracts,它有一个映射到company.company_id的company_id列。

如何编写select语句来获取所有未分配到有效委外的有效公司?即在subcontracts.company_id中找不到company_id

*编辑*

我相信正确的sql是:

代码语言:javascript
复制
select company_id 
from company 
where company.active_status = 1 
and not exists( select * from subcontracts 
                where subcontracts.company = company.company_id 
                AND subcontracts.active_status = 1
              )
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-05-11 05:59:25

子选择在LINQ中基本相同。

代码语言:javascript
复制
var noSubs = from company in context.Companies
             where company.active_status == 1 &&
                 !(from subcontract in context.Subcontracts
                  where subcontract.active_status == 1
                  select subcontract.company_id).Contains(company.company_id)
             select company;

Linq to SQL会将其转换为分包表上的"not exists“。

票数 2
EN

Stack Overflow用户

发布于 2010-05-11 04:05:25

弄清楚如何在标准SQL中做到这一点,然后拿起Linqer (http://www.sqltolinq.com/)的副本。该产品可以将几乎任何SQL语句转换为LINQ查询。它不是免费的,但也不贵,而且有30天的试用期。我发现它非常有用。

票数 1
EN

Stack Overflow用户

发布于 2010-05-11 04:29:30

听起来像是你在尝试做一个WHERE NOT IN,比如:

代码语言:javascript
复制
var companiesWithoutSubcontracts = 
        from noSub in Companies
        where !(from withSub in Companies
                select withSub.company_id)
               .Contains(noSub.company_id)
        select noSub;

`

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2805965

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档