未正确返回

本文关键字:返回 | 更新日期: 2023-09-27 18:35:49

我试图获取另一个列表中尚不可用的员工列表。 但是我只从数组列表中获取第一个元素。例如:如果我尝试EmployeeId = new int[2] {5, 2};仅排除"5"的列表。所以请帮我更正下面的代码。

public JsonResult GetEmployees(int[] EmployeeId)
    {            
        var dbs = new dbContext();
        if (EmployeeId != null)
        {
            foreach (var emp in EmployeeId)
            {
               var EmpList = dbs.Employees.Select(e => new
                   {
                       EmployeeId = e.EmployeeId,                          
                       Name = e.EmployeeName,
                       Job = e.Job.JobName,
                       Currency = e.Currency.CurrencyName,
                       Amount = e.Amount
                   }).Where(o => o.EmployeeId != emp);
              return Json(EmpList, JsonRequestBehavior.AllowGet);
            }
        }   
          return null
    }

未正确返回

试试这个:

var employeeList = dbs.Employees.
             .Where(e => EmployeeId.All(x=> x != e.EmployeeId))
             .Select(e => new
             {
               EmployeeId = e.EmployeeId,                          
               Name = e.EmployeeName,
               Job = e.Job.JobName,
               Currency = e.Currency.CurrencyName,
               Amount = e.Amount
             });
         return Json(EmpList, JsonRequestBehavior.AllowGet);
       }

您是否尝试过逐步执行代码?

你的 foreach 遍历你的 EmployeeId 数组。由于 foreach 中有一个 return 语句,因此它会在此时退出函数,并且只使用数组的第一个元素。

你需要这样的东西:

public JsonResult GetEmployees(int[] EmployeeId)
        {
            var dbs = new dbContext();
            if (EmployeeId != null)
            {                
                var EmpList = dbs.Employees.Where(EmployeeId.Contains(e.EmployeeId))
                .Select(e => new
                {
                    EmployeeId = e.EmployeeId,
                    Name = e.EmployeeName,
                    Job = e.Job.JobName,
                    Currency = e.Currency.CurrencyName,
                    Amount = e.Amount
                }).Where(o => o.EmployeeId != emp);
                return Json(EmpList, JsonRequestBehavior.AllowGet);               
            }
            return null;
        }