列出子查询中提到的表中的列(MySQL)

时间:2020-01-08 07:38:08

标签: mysql sql nested-queries

考虑三个表格-演员,角色和电影

mysql> DESCRIBE actors;
+------------+--------------+------+-----+---------+-------+
| Field      | Type         | Null | Key | Default | Extra |
+------------+--------------+------+-----+---------+-------+
| id         | int(11)      | NO   | PRI | 0       |       |
| first_name | varchar(100) | YES  | MUL | NULL    |       |
| last_name  | varchar(100) | YES  | MUL | NULL    |       |
| gender     | char(1)      | YES  |     | NULL    |       |
+------------+--------------+------+-----+---------+-------+
4 rows in set (0.17 sec)

mysql> DESCRIBE roles;
+----------+--------------+------+-----+---------+-------+
| Field    | Type         | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+-------+
| actor_id | int(11)      | NO   | PRI | NULL    |       |
| movie_id | int(11)      | NO   | PRI | NULL    |       |
| role     | varchar(100) | NO   | PRI | NULL    |       |
+----------+--------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> DESCRIBE movies;
+-----------+--------------+------+-----+---------+-------+
| Field     | Type         | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+-------+
| id        | int(11)      | NO   | PRI | 0       |       |
| name      | varchar(100) | YES  | MUL | NULL    |       |
| year      | int(11)      | YES  |     | NULL    |       |
| rankscore | float        | YES  |     | NULL    |       |
+-----------+--------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

以下查询列出了电影“辛德勒的名单”中所有演员的名字和姓氏:

mysql> SELECT first_name, last_name FROM actors WHERE id IN
    -> (SELECT actor_id FROM roles WHERE movie_id IN
    -> (SELECT id FROM movies WHERE name='Schindler\'s List')
    -> ) ORDER BY first_name;

假设我想列出演员所扮演的角色以及他们的名字和姓氏,那么最好的查询将是什么以获取所需的结果集或输出?可能需要注意的是,该角色是“角色”表中位于“子查询”中的一列。

1 个答案:

答案 0 :(得分:2)

SELECT DISTINCT a.first_name, a.last_name, r.role 
FROM actors a, roles r, movies m 
WHERE a.id = r.actor_id  and r.movie_id  = m.id and m.name='Schindler\'s List'
ORDER BY first_name;

或者您可以通过联接使用

SELECT DISTINCT a.first_name, a.last_name, r.role 
FROM roles r 
  INNER JOIN  actors a ON a.id = r.actor_id 
  INNER JOIN movies m  ON r.movie_id  = m.id 
WHERE m.name='Schindler\'s List'
ORDER BY first_name;