[英]Get distinct values from list
public List<MAS_EMPLOYEE_TRANSFER> GetEmployeeTransferListForHR(TimecardDataContext TimecardDC)
{
List<MAS_EMPLOYEE_TRANSFER> objEmployeeTransferList = null;
try
{
objEmployeeTransferList = new List<MAS_EMPLOYEE_TRANSFER>();
objEmployeeTransferList = TimecardDC.MAS_EMPLOYEE_TRANSFER.Where(
employee =>
employee.HR_ADMIN_IND=="Y").ToList();
}
finally
{
}
return objEmployeeTransferList;
}
它显示 hr admin indicator=yes 的所有值列表。 但是我必须从MAS_EMPLOYEE_TRANSFER
表中获取hr admin=yes
和 distinct(empid) 。 如何获得不同empId
从该objEmployeeTransferList
。
List<int> ids = objEmployeeTransferList
.Select(e => e.empId)
.Distinct()
.ToList();
您也可以在服务器端进行此操作,而无需创建包含所有管理员记录的内存员工列表:
List<int> ids = TimecardDC.MAS_EMPLOYEE_TRANSFER
.Where(e => e.HR_ADMIN_IND == "Y")
.Select(e => e.empId)
.Distinct()
.ToList();
使用 GroupBy 区分
objEmployeeTransferList.GroupBy(x => x.empId).Select(g => g.First()).ToList();
你有没有试过:
objEmployeeTransferList = TimecardDC.MAS_EMPLOYEE_TRANSFER.Where(
employee => employee.HR_ADMIN_IND=="Y").Distinct().ToList();
linq 中有一个独特的方法应该可以解决问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.