我正在制作一个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();