快乐SQL做题 - Day1

Hello!!我回归啦~ 今天开始继续刷SQL的题目~ 争取这个寒假可以在SQL有一点点进步!

闯关开始啦

关卡1 - 组合两个表

思路:

这道题说不管person是否有信息都应该被merge。所以我们应该把有person的那张表作为主表,然后把另一张表left join进来,这样就可以确保person都存在。

那是不是这样就好了呢?

SELECT FirstName,LastName FROM Person

LEFT JOIN  Address

ON Person.PersonId = Address.PersonId

错!这里,兔子还遇到一个问题,就是我们并没有提供city和state

但是city 和 state 明明是在另外的一个表格,怎么才能让他也被选择进来呢?我们可以在第一行就输入这两个来自另一个表格的变量。

SELECT FirstName,LastName,City,State FROM Person

LEFT JOIN  Address

ON Person.PersonId = Address.PersonId

这样就运行成功啦!However,为了让他更加直观,我们一般会在第一行的这些变量前面加上一个表格的首字母.

所以就是:

SELECT P.FirstName, P.LastName, A.City, A.State  FROM Person P

LEFT JOIN  Address A

ON P.PersonId = A.PersonId

恭喜过关!进入下一关!


关卡2 - 第二高的薪水

思路:

这道题看起来好像挺简单的!

他想要生成一个新的列,我们就用AS关键字,想要排序,我们就进行ORDER BY,想要从大到小,我们就descending order用DESC,想只生成第二个,我们就LIMIT 1 OFFSET 1,这些语法在我之前的文章都介绍过了~

所以我刷刷刷写下来如下代码

SELECT DISTINCT Salary AS SecondHighestSalary 

FROM Employee

ORDER BY SecondHighestSalary DESC

LIMIT 1 OFFSET 1

但是!提交之后显示错误了。

那么问题出在哪里呢~问题就是,当不存在第二高的薪水时,系统并没有返回NULL

所以我们要把我们之前的代码作为一个临时表,我们要做一个表中表,可以用到IFNULL语句,语法是:IFNULL((语句),如果前面的语句是null的时候返回的东西)

那这里就是IFNULL((前面的代码),NULL)

组合起来就是:

SELECT IFNULL(

(SELECT DISTINCT Salary 

FROM Employee

ORDER BY Salary DESC

LIMIT 1 OFFSET 1),NULL) AS SecondHighestSalary

恭喜过关!进入下一关!


关卡3 - 第N高的薪水

思路:

其实这道题和第二题很像,但是它是以一个N的形式出现

题目本身帮助我们定义了一个函数

CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT

BEGIN

    RETURN ();

END

我们的任务就是在return里面写代码~

我的第一反应是,那就复制之前的代码,然后把OFFSET 那里改成(N-1),然鹅🦢,并没有那么顺利,我成功bug了

后来才知道,原来要在前面SET一个变量,让这个变量等于N-1,然后再OFFSET这个变量

那么答案就是:

CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT

BEGIN

    SET n = N-1;

    RETURN (

     SELECT IFNULL(

     (SELECT DISTINCT Salary 

     FROM Employee

     ORDER BY Salary DESC

     LIMIT 1 OFFSET n),NULL) AS SecondHighestSalary);

END

当然,也可以LIMIT n,1 而不要OFFSET,但是意思是一样的啦~LIMIT x,y ,是跳过x行,取y行数据的意思,类似于 limit y offset x

恭喜过关!进入下一关!


关卡4 - 分数排名

思路:

这道题其实说实话,兔子不懂。

哈哈哈哈哈哈哈~这么坑的嘛~~

所以呢,我就看了题解,发现了我没学过的东西~

那就是SQL的排名函数,也叫窗口函数,解释如下:

那这样一来,这道题就变得很简单啦,它需要我们用dense_rank() 函数来解决~

它的语法是直接在SELECT语句里面,在select之后,dense_rank()  over (你要进行的处理) AS ‘一个新的列名’ From 表格名

如下:

SELECT Score,

dense_rank( ) over (ORDER BY Score DESC) AS 'Rank'

From Scores

恭喜过关!进入下一关!


关卡5 - 连续出现的数字

思路:

自连接(自身连接),把一张表复制出多张一模一样的表来使用。然后我们找出下面一行和上面一行,如果这三个数字相等,说明他出现了三次。

那我们开始写code!

步骤1: 连接三表

SELECT * FROM Logs AS a, Logs AS b, Logs AS c 

WHERE a.Id = b.Id + 1

AND a.Id = c.Id - 1

AND a.NUM = b.NUM

AND a.NUM = c.NUM

这时,最后两行代码限制了,这三个数字必须相等才能留在这个表格

所以我们只需在SELECT语句加一个distinct,就能找出,重复三次的数字究竟是什么!

SELECT DISTINCT a.Num AS ConsecutiveNums 

FROM Logs AS a,Logs AS b,Logs AS c

WHERE a.Id = b.Id + 1

AND a.Id = c.Id - 1

AND a.Num = b.Num

AND a.Num = c.Num

恭喜过关!

今天学到的新知识:SET,IFNULL 函数,limit X,Y = limit Y offset X, 窗口函数dense_rank()over(), rank()over(), row_number()over(), 自连接。

明天继续闯关~yay ~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容

  • 第一次玩简书,格式还不太会设置,大家见谅,排版好的文章在公众号“八哥的成长心路札记”上有,微信号是bager191...
    albert184阅读 738评论 0 0
  • 力扣题目资源来自“熊大的数据分析之路”,写下这系列练习记录是为了自己实践一遍,非商业用途。 1. 组合两个表 表1...
    元宝2020阅读 749评论 1 0
  • 176. 第二高的薪水[https://leetcode-cn.com/problems/second-highe...
    1nvad3r阅读 46评论 0 0
  • 前面俩个章节我们介绍了窗口函数、滑动窗口函数的概念,接下来我们介绍一下PG支持的原生通用窗口函数,总共11个(9....
    码农大表哥3306阅读 2,115评论 2 3
  • 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句。 问题及描述: --1.学生表 Stud...
    lijun_m阅读 1,300评论 0 1