gpt4 book ai didi

mysql - linq 中的 Intersect 或 Except 方法在 MYSQL 中不起作用

转载 作者:行者123 更新时间:2023-11-28 23:27:24 30 4
gpt4 key购买 nike

我在 mysql 中使用 Entity Framework 。我必须在其中一个查询中使用 Intersect,但它会抛出错误“不支持指定的方法。”。除了将数据存入内存并在其上应用 Intersect 之外,任何人都可以提出替代方案。

public List<share> GetFeed(List<long> UserRules, List<long> ListedShares, string AuthorID)
{
List<share> listshare = DbContext
.shares
.Where(x => UserRules.Intersect(x.share_rules.Select(y => y.rule_id)).Any())
.ToList();
return listshare;
}

最佳答案

不支持指定的方法。 表示 EntityFramework 无法将其转换为 SQL 查询。实际上,在大多数情况下,可以将其转换为支持的Contains。你应该改变你的方法来匹配:

public List<share> GetFeed(List<long> UserRules, List<long> ListedShares, string AuthorID)
{
List<share> listshare = DbContext
.shares
.Where(x => x.share_rules.Any(y => UserRules.Contains(y.rule_id)))
.ToList();
return listshare;
}

关于mysql - linq 中的 Intersect 或 Except 方法在 MYSQL 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38735341/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com