我首先使用 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/