没有正确返回

Not Returning properly

我正在尝试获取另一个列表中尚不可用的员工列表。但我只从数组列表中获取第一个元素。 例如:如果我尝试 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
    }

您试过单步执行代码吗?

您的 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;
        }

试试这个:

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);
       }