Как получить запись с максимальной датой с присоединением? - PullRequest
3 голосов
/ 29 марта 2019

Как я могу сделать это в LINQ?

select  MAX(d.DepartureDateRange),MAX(d.ReturnDateRange)   
from Tour t join
TourCategory tc on t.ID = tc.TourID
join TourDates td on t.ID = td.TourID
join Dates d on d.ID = td.DatesID
where tc.CategoryID = 3 and t.ID = 12 

Диаграмма базы данных здесь ->

dbdiagram

Например, соединения такие, но я не могу получить Max of DepartureDateRange & ReturnDateRange

var query2 = from t in db.Tour
    join tc in db.TourCategory on t.ID equals tc.TourID
    join td in db.TourDates on t.ID equals td.TourID
    join d in db.Dates on td.DatesID equals d.ID
    where tc.CategoryID == 3
    select new IndexTour
    {
        ID = t.ID,
        TourName = t.TourName,
        //DepartureDateRange = 
        //ReturnDateRange = 
        Description = t.SmallDesc,
        Price = t.Price,
        CoverPhotoUrl = t.CoverPhotoUrl,
        TourProgram = t.TourDesc
    };

Заранее спасибо.

Ответы [ 2 ]

2 голосов
/ 30 марта 2019

Вот оно (даты сгруппированы по турам):

var query2 = 
    from t in db.Tour
    join tc in db.TourCategory on t.ID equals tc.TourID
    where tc.CategoryID == 3
    // join dates aggregates grouped by tour id
    join tdates in
        from td in db.TourDates 
        join d in db.Dates on td.DatesID equals d.ID
        group d by td.TourID into grp
        select new 
        { 
            tourID = grp.Key, 
            departure = grp.Max(g => g.DepartureDateRange), 
            rtrn = grp.Max(g => g.ReturnDateRange)
        }
    on t.ID equals tdates.tourID
    select new IndexTour
    {
        ID = t.ID,
        TourName = t.TourName,
        DepartureDateRange = tdates.departure,
        ReturnDateRange = tdates.rtrn,
        Description = t.SmallDesc,
        Price = t.Price,
        CoverPhotoUrl = t.CoverPhotoUrl,
        TourProgram = t.TourDesc
    };
0 голосов
/ 29 марта 2019

Я думаю это то, что вы хотите?

var dateRanges = tours
    .Join(tourCategories,
        t => t.Id,
        tc => tc.TourId,
        (t, tc) => (t, tc))
    .Join(tourDates,
        ttc => ttc.t.Id,
        td => td.TourId,
        (ttc, td) => (ttc, td))
    .Join(dates, 
        ttctd => ttctd.td.DateId,
        d => d.Id,
        (ttctd, d) =>
        new {
            TourId = ttctd.ttc.t.Id,
            CategoryId = ttctd.ttc.tc.CategoryId,
            DepartureDateRange = d.DepartureDateRange,
            ReturnDateRange = d.ReturnDateRange
        });

var filtered = dateRanges
    .Where(r => r.CategoryId == 3 && r.TourId == 12);

var maxDepartureDateRange = filtered.Max(d => d.DepartureDateRange);
var maxReturnDateRange = filtered.Max(d => d.ReturnDateRange);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...