我有一个电影数据库,其中包含电影、演员和导演的表格。每部电影在电影表中占据一行。几乎我所有的查询都需要连接到其他表,这样一个 LIMIT 50、偏移量 0 的查询会返回大约 4 部电影的完整数据。下面是一个示例查询。我该如何修改它以确保获取正好 10 部电影的数据?
SELECT movie.id, movie.title, star.name, star.name_url, dir.name,
dir.name_url, genre.name, genre.name_url
FROM movie
LEFT JOIN actor
ON (movie.id = actor.movie_id)
LEFT JOIN person AS star
ON (actor.person_id = star.id)
LEFT JOIN director
ON (movie.id = director.movie_id)
LEFT JOIN person AS dir
ON (director.person_id = dir.id)
LEFT JOIN genre_classification
ON (movie.id = genre_classification.movie_id)
LEFT JOIN genre
ON (genre_classification.genre_id = genre.id)
WHERE (movie.id > 0)
ORDER BY movie.id
LIMIT 50 OFFSET 0;
我正在使用可能无关紧要的 PostgresSQL。