0

我只需要返回第一条记录。虽然我不得不把 z.FirstOrDefault(); 仍然显示了不止一个

           public DataTable GetDependents(string EmployeeID)
    {
        HealthCareSystem.DataClassesDataContext db = new HealthCareSystem.DataClassesDataContext();

        var z = (from s in db.SelectingDependentsGroupBies
                 where s.EmployeeID.Equals(EmployeeID)
                 join d in db.Dependents on s.DependentID equals d.DependentID
                 orderby s.DependentID descending

                 //Selecting wanted tables dependents fields by datatable
                 select new DependentsX { DependentID = Convert.ToInt32(s.DependentID), EmployeeID = s.EmployeeID, Name = s.Name, Surname = s.Surname, IDCardNo = s.IDCardNo, ContactNo = s.ContactNo, BirthDate = s.BirthDate, StartSchemeDate = s.StartDate, EndSchemeDate = s.EndDate, RelationType = s.Type, Payment = Convert.ToDouble(d.Payment), });

        var firstRecord = z.FirstOrDefault(); 
4

2 回答 2

1

在现有代码之后添加这一行:

var firstRecord = x.First();

如果结果可能为零并且您不希望出现异常,则可以FirstOrDefault改用。

var firstRecord = x.FirstOrDefault();
于 2012-07-26T14:54:09.590 回答
0

另一种常见的方法是将查询括在括号中,然后在括号外包含扩展方法:

var x = (from d in db.DependentsRelationsViews 
        where d.IDCardNo.Equals(DepID) 
        orderby d.DependentID descending 
        select new DependentsX  
        {  
            DependentID = Convert.ToInt32(d.DependentID),  
            EmployeeID = d.EmployeeID,  
            Name = d.Name,  
            Surname = d.Surname,  
            IDCardNo = d.IDCardNo,  
            ContactNo = d.ContactNo,  
            BirthDate = d.BirthDate,  
            StartSchemeDate = Convert.ToDateTime(d.StartSchemeDate),  
            EndSchemeDate = d.EndSchemeDate,  
            Payment = d.Payment,  
            RelationType = Convert.ToString(d.Type) 
        }).FirstOrDefault(); 

如果您不将其括在括号中并尝试调用,FirstOrDefault()那么您将在最后一个Select子句中将该扩展应用于匿名类型。通过将整个查询括在括号中然后调用FirstOrDefault()扩展,您向编译器指示您希望将其应用于整个查询的返回值,即IEnumerable<>orIQueryable<>集合。

于 2012-07-26T15:16:43.130 回答