gpt4 book ai didi

c# - 为什么我的 LINQ to Objects 查询没有返回任何结果?

转载 作者:太空宇宙 更新时间:2023-11-03 14:35:55 25 4
gpt4 key购买 nike

我正在使用以下查询(主要来 self 收到的帮助 here ):

    public IEnumerable<Entities.AuditAgency> GetAuditRuleAgencyRecords(IEnumerable<Entities.AuditRuleEnterprise> rules)
{
using (LinqModelDataContext db = new LinqModelDataContext())
{
// Left-Outer Joins on Agency and its various other tables.
var auditAgencyRecords = (from ag in db.Agencies
join ara in db.AuditRuleAccounts on ag.Agency_Id equals ara.AgencyID into aran
from ara in aran.DefaultIfEmpty()
join arr in db.AuditRuleResults on ara.AuditRuleAccountID equals arr.AuditRuleAccountID into arrn
from arr in arrn.DefaultIfEmpty()
join are in db.AuditRuleEnterprises on arr.AuditRuleEnterpriseID equals are.AuditRuleEnterpriseID into aren
from are in aren.DefaultIfEmpty()
select new
{

AgencyID = ag.Agency_Id,
AgencyName = ag.Agency_Name,
AuditRuleEnterpriseID = arr.AuditRuleEnterpriseID,
AuditRuleEnterpriseName = are.OverrideDisplayName,
CorrectedDate = arr.CorrectedDate,
NbrDaysToCorrect = arr.NbrDaysToCorrect,

});

IEnumerable<AuditAgency> AuditAgencies = auditAgencyRecords
.GroupBy(a => a.AgencyID)
.Select(ag => new AuditAgency()
{
AgencyID = ag.Key,
AgencyName = ag.First().AgencyName,
Rules = ag
.GroupBy(agr => agr.AuditRuleEnterpriseID)
// ----> Do a left outer join on parameter "rules" object and the returned group above
// ----> on both of their ID's
.Select(agrg => new AuditAgencyRule() // Now I would like to only be creating "rules" for the rules with IDs that match the rules passed into this method
{
AuditRuleID = agrg.Key,
AuditRuleName = agrg.First().AuditRuleEnterpriseName,
Days = (Int32)agrg.Average(agrgr => agrgr.NbrDaysToCorrect)
})
}).ToList();

return AuditAgencies;

}

这会返回一个 AuditAgency 对象列表,每个 AuditAgency 都包含一个 AuditAgencyRules 列表。

现在,作为此查询的最后一步,也是我遇到问题的部分...是,您可以看到一个 IEnumerable 规则作为参数传入此方法。

我想做的是,在我的第二个查询中,它为每个机构创建了一个规则列表,我想对我的本地“规则”对象执行左外连接。我传入的每个规则对象都有一个 rule.ID。我希望每个机构只包含传入的规则,如果没有它们的数据,则只需将其内容保留为空即可。

现在,我的查询包含从数据库返回的所有规则及其数据。但是,我需要它只包含传递给方法的规则,而不管它是否与从数据库返回的规则匹配。所以换句话说,我需要使用我现在拥有的规则对我的本地“规则”对象执行左外连接。

你可以看到我在上面的代码中添加了注释,以解释我在哪里以及我想做什么。

因此,如果“rules”仅包含 3 个设置了 ID 的规则,则此查询将只返回每个机构的这 3 个规则,而不管这些规则是否有数据(其数据将为空)。而不是返回每个机构的所有规则,这是它现在所做的。

如何在我的 LINQ to SQL 查询中为“本地”对象编写此左外连接?


这是我在上面的第二个查询之后对我的“规则”对象和我的 AuditAgencies 中的规则进行左外连接的尝试:

foreach (var agency in AuditAgencies)
{
agency.Rules = from rule in rules
join lr in agency.Rules on rule.EnterpriseID equals lr.AuditRuleID into g
from lr in g.DefaultIfEmpty()
select new AuditAgencyRule
{
AuditRuleID = rule.EnterpriseID,
AuditRuleName = rule.Name,
Days = lr.Days,
Flagged = lr.Flagged,
PercentFlagged = lr.PercentFlagged
};
}

没有骰子。现在,我得到的不是所有规则,而是 ~no~ 规则。当我只想获取传递给此方法的规则时。

有人能指出我正确的方向吗?

最佳答案

我可以为您提供一些元帮助。你应该去抢LINQPad并开始使用 .Dump() 来查看哪里出了问题(您也可以查看直接的 SQL 翻译)。

关于c# - 为什么我的 LINQ to Objects 查询没有返回任何结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1110010/

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