LINQ to Entites и ObjectQuery
У меня есть лицо, которое имеет отношение 1: N к Person_Addresses
(поля: PersonID
, AddressID
, ValidFrom
). Я хочу получить все Person
записи и связанные Person_Addresses
только с последним ValidFrom. Как я должен сделать это, используя ObjectQuery или IQueryable?
Изменить: я упомянул ObjectQuery
а также IQueryable
потому что я хотел иметь решение с использованием методов расширения (я думаю, так оно и называется). Также я забыл упомянуть, что я использую Entity Framework, где у меня созданы объекты. Я хочу получить объект person, в который загружен член person_adress.
Вот структура сущностей: члены-члены: int id, строка firstname, string lastname, Partner_Address partneradress
Персоны_адрес участников: int personid
, int adressid
, date validfrom
1 ответ
Попробуйте следующее.
У меня есть следующие лица.
//Person Entity
public class Person
{
public int PersonID { get; set; }
public string PersonName { get; set; }
}
//PersonAddress Entity
public class PersonAddress
{
public int PersonID { get; set; }
public int AddressID { get; set; }
public DateTime ValidFrom { get; set; }
}
Затем запустите следующий запрос.
//Get the latest ValidFrom for each person from PersonAddress.
var getLatestDateRecords =
from p in lstPersonAddress
group p by p.PersonID into g
select new
{
Infos =
(from PA in g
select new
{
PersonId = PA.PersonID
Date = g.Max(t=>t.ValidFrom)
}).Distinct()
};
//Segregate the ValidFroms and PersonId from the
//previous record set(getLatestDateRecords).
var segRecords =
from x in getLatestDateRecords
from y in x.Infos
select new { Date = y.Date, PersonId = y.PersonId };
//Obtain all the relevant information from the PersonAddress
// for the latest ValidFrom dates.
var allValidRecords =
from PA in lstPersonAddress
join x in segRecords
on PA.ValidFrom equals x.Date
where PA.PersonID == x.PersonId
select new {
PersonId = PA.PersonID
, AddressId = PA.AddressID
, Date = PA.ValidFrom
};
//Get the final result
var resultSet =
from p in lstPerson
join x in allValidRecords
on p.PersonID equals x.PersonId
select new
{
PersonId = p.PersonID
,PersonName = p.PersonName
,AddressId = x.AddressId,
Date = x.Date
};
Я обнаружил, что он работает нормально с некоторыми тестовыми данными.
Дайте мне знать в случае каких-либо проблем.