The Filmorate project — это бэкенд приложения для работы с базой данных фильмов. А также площадка для общения и взаимодействия пользователей.
- Хранение данных о фильмах
- Хранение данных о пользователях
- Возможность пользователям ставить лайки фильмам
- Возможность пользователям добавлять друг друга в друзья
- Возможность получать рейтинг TOP_N фильмов по количеству лайков
- Возможность получать общих с другим пользователем фильмов с сортировкой по их популярности
- Возможность заводить друзей
- Возможность оставлять отзывы о фильмах
- Фильмы содержат возрастные ограничения по стандарту MPPA
- Реализован поиск по названию и режиссерам
- Реализована система жанров для фильмов
- Есть лента событий
Для запуска проекта требуется: - Java версии 21
Приложение работает на порту 8080
Откройте терминал в корне проекта и выполните команды для запуска приложения.
Вариант 1 Spring
mvn spring-boot:run
- для остановки CTRL+C
Вариант 2 Java
mvn package
cd ./target/
java -jar filmorate-0.0.1-SNAPSHOT.jar
- для остановки CTRL+C
Вариант 3 Docker
mvn package
sudo docker build -t filmorate-image .
sudo docker run --name filmorate -p 8080:8080 filmorate-image
- для остановки
sudo docker stop filmorate
Для работы с приложением используйте REST-клиент
- Postman
- Insomnia
- RestFox
- и подобные
- Get TOP-10 films:
SELECT f.film_name,
sum(l.user_id) AS rate
FROM films f
JOIN likes l ON f.id = l.film_id
GROUP BY f.film_name
ORDER BY rate DESC
LIMIT 10;- Get all the movies liked by users 5, 6 and 7 with a duration of more than 100 minutes and with genres of adventure, horror, action.
SELECT f.film_name,
f.release_date,
f.duration
FROM films f
WHERE f.id IN
(SELECT l.film_id
FROM likes l
WHERE l.user_id IN
(SELECT friend_id
FROM friends fr
WHERE fr.user_id IN (5, 6, 7)
)
)
AND f.duration > 100
AND f.id IN
(SELECT fg.film_id
FROM genres_of_films fg
WHERE fg.genre_id IN
(SELECT g.id
FROM genres g
WHERE g.genre_name
IN('Боевик', 'Триллер', 'Комедия')
)
);

