select distinct on (author.id)
book.id, author.id, author.name, book.title as last_book
from
author
inner join
book on book.author_id = author.id
order by author.id, book.id desc
Sprawdź distinct on
W przypadku opcji differ na konieczne jest uwzględnienie "odrębnych" kolumn w order by
. Jeśli nie jest to kolejność, którą chcesz, musisz zawinąć zapytanie i zmienić kolejność
select
*
from (
select distinct on (author.id)
book.id, author.id, author.name, book.title as last_book
from
author
inner join
book on book.author_id = author.id
order by author.id, book.id desc
) authors_with_first_book
order by authors_with_first_book.name
Innym rozwiązaniem jest użycie funkcji okna, jak w odpowiedzi Lennarta. Innym bardzo ogólnym jest to
select
book.id, author.id, author.name, book.title as last_book
from
book
inner join
(
select author.id as author_id, max(book.id) as book_id
from
author
inner join
book on author.id = book.author_id
group by author.id
) s
on s.book_id = book.id
inner join
author on book.author_id = author.id