c# – LINQ查询仅加入最后一个值

我正在制作一个ASP.NET C#库系统. Het(MSSQL)数据库设计的截图:

要显示书籍,我使用租赁表.
但是有我的问题:

>我离开了Books表并使用Rentals表(因为还有一些尚未租借的书籍,需要显示(参见ID为3的书)
>当我刚刚离开加入时,我在书中多次看到我的书籍 – 概述……
> SO:我应该需要一个LINQ查询来连接Books with Rentals,但是如果这些书已经被租了多倍,他应该只加入该book_id表中的最后一个值
>查看下图:查询应该只选择绿色选择的值…
>(额外信息:如果有人租一本书,返回的值= 0,如果他退还了这本书,它就变成1)

我现在的查询是:

var query = (from b in db.Books
                     join a in db.Authors on b.author_id equals a.author_id
                     join c in db.Categories on b.category_id equals c.category_id
                     join r in db.Rentals on b.book_id equals r.book_id into lf
                     from r in lf.DefaultIfEmpty()
                     select new BookDetails(
                                b.book_id,
                                b.title,
                                b.ISBN,
                                b.description,
                                b.author_id,
                                a.firstName,
                                a.lastName,
                                b.category_id,
                                r.returned == null ? 1 : r.returned)
                     ).ToList();

但就像我说的那样,这会多次显示我租来的书……
我一直在想“MAX”属性? (但是这适用于linq吗?)

最佳答案 您可以按书籍ID对书籍进行分组,然后从每个组中选择第一个项目.这是如何模拟“不同”的巧妙方法.在你的情况下,将是

var query = (from b in db.Books
             join a in db.Authors on b.author_id equals a.author_id
             join c in db.Categories on b.category_id equals c.category_id
             join r in db.Rentals on b.book_id equals r.book_id into lf
             from r in lf.DefaultIfEmpty()
             group new{ Book = b, Author = a, Rental = r }
                 by b.book_id into booksById
             let item = booksById.First()
             select new BookDetails(
                 item.Book.book_id,
                 item.Book.title,
                 item.Book.ISBN,
                 item.Book.description,
                 item.Book.author_id,
                 item.Author.firstName,
                 item.Author.lastName,
                 item.Book.category_id,
                 item.Rental.returned == null
                     ? 1 : item.Rental.returned))
             .ToList();
点赞