最近一次面试时做的笔试题目,虽然很简单,但是我挺有印象的。做过很多笔试题目,这应该是第一个让我觉得挺有印象的数据库笔试题。
题目大概是这样的:
有一张表 rail 存储着上海地铁线路的信息。line 表示线路,stop 表示站点名称,sequence 表示站点在线路上的顺序。(为了简洁,我直接用 SQL 语句表示数据)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
|
题目的要求有两个:
1、查询经过站点最多的站点。
2、给出任意两条线路,查询这两条线路换乘的站点。
第一个要求很简单,直接用下面的语句完成就可以了。
1 2 |
|
倒是第二个要求,我在第一次思考的时候就踩坑了,我写了一个非常低级错误的 SQL。
1
|
|
刚写完最后的分号我就反应过来了,这里不对,正确的做法是得让 rail 表自己和自己 join 之后查询。于是思考了一小会儿写下了第二个 SQL。
1 2 |
|
题目是挺简单的,只是我今后不能直接靠直觉去想解题的思路,还是要多思考一会儿,把解决问题的步骤想清楚。