Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/linq/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# C Linq或查询IEnumerable_C#_Linq_For Loop_Inner Join_Ienumerable - Fatal编程技术网

C# C Linq或查询IEnumerable

C# C Linq或查询IEnumerable,c#,linq,for-loop,inner-join,ienumerable,C#,Linq,For Loop,Inner Join,Ienumerable,我有一个员工表,其中也有部门经理信息。我需要填充两个下拉列表-一个是员工,另一个是经理。我现在只查询一次表,并将所有信息存储在缓存中的IEnumerable EmployeeList中,而不是使用两个查询来拉取员工和另一个查询来拉取经理 我需要一些查询来从该查询中提取管理器-使用LINQ或C代码中的循环。我写了一个循环,但效率很低 以下是用于填充HCache的SQL查询: SELECT [Dept_Mgr_ID] As MgrId, EmployeeId,

我有一个员工表,其中也有部门经理信息。我需要填充两个下拉列表-一个是员工,另一个是经理。我现在只查询一次表,并将所有信息存储在缓存中的IEnumerable EmployeeList中,而不是使用两个查询来拉取员工和另一个查询来拉取经理

我需要一些查询来从该查询中提取管理器-使用LINQ或C代码中的循环。我写了一个循环,但效率很低

以下是用于填充HCache的SQL查询:

    SELECT [Dept_Mgr_ID] As MgrId,
            EmployeeId,
        EmpLastName,
        EmpFirstName
        FROM Employee_tbl
在这里,我试图通过缓存循环并加入EmployeeId和MgrId

            List<DTO.Employee> Mgrs = new List<DTO.Employee>(0);
            for (int i = 0; i < HCache.EmployeeList.Count(); i++)
            {
                foreach(var e in HCache.EmployeeList)
                {

                    if (HCache.EmployeeList.ElementAt(i).EmployeeId == e.MgrId)
                    {

                        Mgrs.Add(new DTO.Employee() { MgrID = e.MgrId,

                            ManagerLastName = e.EmpLastName,
                            ManagerFirstName = e.EmpFirstName
             });
                    }
                }
            }

我想说您应该使用第二个SQL查询来获取管理器,但我会尝试加快代码的速度

问题:

假设EmployeeList是一个IEnumerable,EmployeeList.ElementAti是一个On操作,即慢速操作。这是一个隐藏在幕后的嵌套循环。 员工列表。计数是一个On操作,即慢速。 代码的结果复杂性为^3,即非常慢。 如何改善:

只需执行一次操作,即可构建从EmployeeId到Employee或存储在HCache.EmployeeList中的任何内容的映射。这将使您能够通过O1中的id快速找到它们。 再做一次通过员工列表收集经理。 总体复杂性为On,即与EmployeeList集合的大小成比例。 下面是一些代码来说明这个想法:

类电磁脉冲{ public int EmployeeId{get;set;} 公共int-MgrId{get;set;} 公共字符串EmpLastName{get;set;} } IEnumerable EmployeeList=新列表{ 新Emp{EmployeeId=1,MgrId=0,employstname=boss}, 新Emp{EmployeeId=2,MgrId=1,employstname=dude}; IDictionary dict=EmployeeList.ToDictionary=>e.EmployeeId; var经理=员工名单 .Selecte=>dict.TryGetValuee.MgrId,输出Emp管理器?经理:空 .字体 托利斯先生 //列表1{Emp{EmpLastName=boss,EmployeeId=1,MgrId=0}
请注意,此代码可能会在“经理”列表中生成重复项,这可能是您想要的,也可能不是您想要的,但您的代码的行为方式是这样的,因此我保留了该行为。

如果DTO.Employee类有一个属性DTO.Employee Manager不是更好吗?然后,您可以在链接链后向上导航。类似地,该类将具有List DirectReports。我正在尝试拉取两个单独的下拉列表,其中包含员工信息和经理信息。我可以轻松地从缓存中提取员工信息。这里的问题是,经理的循环将永远持续下去。请建议是否有更好的方法来优化代码。
 WITH CTE_Manager_ID
        AS
        (
        SELECT DISTINCT [Dept_Mgr_ID]
        FROM Employee_tbl
        )
        SELECT EmployeeId,
            EmpLastName,
            EmpFirstName
        FROM Employee_tbl Emp
        INNER JOIN CTE_Manager_ID cteMgr 
            ON cteMgr.Dept_Mgr_ID = Emp.EmployeeId