Leetcode数据库题目-618. 学生地理信息报告

一所美国大学有来自亚洲、欧洲和美洲的学生,他们的地理信息存放在如下 `student` 表中。

| name   | continent |
|--------|-----------|
| Jack   | America   |
| Pascal | Europe    |
| Xi     | Asia      |
| Jane   | America   |

写一个查询语句实现对大洲(continent)列的 [透视表](https://zh.wikipedia.org/wiki/%E9%80%8F%E8%A7%86%E8%A1%A8) 操作,使得每个学生按照姓名的字母顺序依次排列在对应的大洲下面。输出的标题应依次为美洲(America)、亚洲(Asia)和欧洲(Europe)。数据保证来自美洲的学生不少于来自亚洲或者欧洲的学生。

对于样例输入,它的对应输出是:

| America | Asia | Europe |
|---------|------|--------|
| Jack    | Xi   | Pascal |
| Jane    |      |        |


**进阶:**如果不能确定哪个大洲的学生数最多,你可以写出一个查询去生成上述学生报告吗?
select
    America,
    Asia,
    Europe
from
(select
    @rownumber:=@rownumber+1 as id,
    name as America
from
    student,(select @rownumber:=0) a
where
    continent = 'America'
order by
    name) america
left join
(select
    @rownumber2:=@rownumber2+1 as id,
    name as Asia
from
    student,(select @rownumber2:=0) a
where
    continent = 'Asia'
order by
    name) asia
on
    america.id = asia.id
left join
(select
    @rownumber3:=@rownumber3+1 as id,
    name as Europe
from
    student,(select @rownumber3:=0) a
where
    continent = 'Europe'
order by
    name) europe
on
    america.id = europe.id

你可能感兴趣的:(Leetcode数据库题目-618. 学生地理信息报告)