gpt4 book ai didi

c# - 将 WHERE NOT IN 或 LEFT JOIN 翻译成 LINQ

转载 作者:太空宇宙 更新时间:2023-11-03 20:29:24 26 4
gpt4 key购买 nike

我首先使用 EF 代码设置了以下域模型:

public class User
{
public virtual int Id { get; set; }
public virtual string Email { get; set; }
public virtual ICollection<UserProcessed> UsersProcessed { get; set; }
}

public class UserProcessed
{
public virtual int Id { get; set; }
public virtual DateTime CreatedAt { get; set; }
public virtual User user { get; set; }
}

我正在尝试将以下 T-SQL 查询转换为 LINQ,但我遇到了一些困难:

SELECT u.Email
FROM Users u LEFT JOIN UsersProcessed up ON u.Id = up.UserId
WHERE up.UserId IS NULL
AND u.CreatedAt BETWEEN '2011-12-01' AND '2011-12-01'

这将返回所有尚未处理的用户(UserId 不存在于 UsersProcessed 表中)。

IEnumerable<User> users = Database.Set<User>().Where(....).ToList();

最佳答案

当生成 SQL 时,这可能不会转换为完全相同的查询,但它应该可以解决问题:

IEnumerable<User> users = Database.Set<User>().Where(u => !u.UserProcessed.Any()).ToList();

关于c# - 将 WHERE NOT IN 或 LEFT JOIN 翻译成 LINQ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8359984/

26 4 0
文章推荐: html - 如何将
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com