Назад к вопросам
Ozon Финтех
Senior
3
Написать SQL-запрос: выбрать имена трёх самых читаемых авторов на данный момент (у которых больше всего книг сейчас на руках).
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Предположим, у нас есть таблицы:
authors(id, name)books(id, author_id)loans(id, book_id, loan_date, return_date)
Чтобы выбрать имена трёх авторов, у которых сейчас на руках больше всего книг (т.е. книги, которые взяты и ещё не возвращены), можно написать запрос:
SELECT a.name, COUNT(*) AS books_on_loan
FROM authors a
JOIN books b ON a.id = b.author_id
JOIN loans l ON b.id = l.book_id
WHERE l.return_date IS NULL
GROUP BY a.id, a.name
ORDER BY books_on_loan DESC
LIMIT 3;
Здесь мы считаем количество книг каждого автора, которые сейчас не возвращены (return_date IS NULL), сортируем по убыванию и берём топ-3.