Leetcode 數(shù)據(jù)庫總結(jié)

175.組合兩個表
表1: Person

+-------------+---------+
| 列名 | 類型 |
+-------------+---------+
| PersonId | int |
| FirstName | varchar |
| LastName | varchar |
+-------------+---------+
PersonId 是上表主鍵
表2: Address

+-------------+---------+
| 列名 | 類型 |
+-------------+---------+
| AddressId | int |
| PersonId | int |
| City | varchar |
| State | varchar |
+-------------+---------+
AddressId 是上表主鍵

編寫一個 SQL 查詢,滿足條件:無論 person 是否有地址信息,都需要基于上述兩表提供 person 的以下信息:
FirstName, LastName, City, State

SELECT FirstName,LastName,City,State
From Person Left Join Address ON (Person.PersonID = Address.PersonID)

知識點:
1屉凯、on條件是在生成臨時表時使用的條件母赵,它不管on中的條件是否為真,都會返回左邊表中的記錄授药。

2士嚎、where條件是在臨時表生成好后,再對臨時表進行過濾的條件悔叽。這時已經(jīng)沒有l(wèi)eft join的含義(必須返回左邊表的記錄)了莱衩,條件不為真的就全部過濾掉。

176.第二高的薪水
編寫一個 SQL 查詢娇澎,獲取 Employee 表中第二高的薪水(Salary) 笨蚁。

+----+--------+
| Id | Salary |
+----+--------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
+----+--------+
例如上述 Employee 表,SQL查詢應該返回 200 作為第二高的薪水。如果不存在第二高的薪水括细,那么查詢應返回 null伪很。

+---------------------+
| SecondHighestSalary |
+---------------------+
| 200 |
+---------------------+

select (select distinct Salary 
from Employee
order by Salary desc
limit 1,1) as SecondHighestSalary

知識點:1.LIMIT X, Y == LIMIT Y OFFSET X

查詢8條數(shù)據(jù),索引從5到12奋单,第6條記錄到第13條記錄

select * from t_user limit 5,8

177.第N高的薪水

CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
BEGIN
    DECLARE P INT;
    SET P = N-1;
  RETURN (
      # Write your MySQL query statement below.
      SELECT
      (SELECT DISTINCT Salary 
      FROM Employee
      ORDER BY Salary DESC
      LIMIT P,1)  
  );
END

178.分數(shù)排名
編寫一個 SQL 查詢來實現(xiàn)分數(shù)排名锉试。如果兩個分數(shù)相同,則兩個分數(shù)排名(Rank)相同览濒。請注意呆盖,平分后的下一個名次應該是下一個連續(xù)的整數(shù)值。換句話說贷笛,名次之間不應該有“間隔”絮短。

+----+-------+
| Id | Score |
+----+-------+
| 1 | 3.50 |
| 2 | 3.65 |
| 3 | 4.00 |
| 4 | 3.85 |
| 5 | 4.00 |
| 6 | 3.65 |
+----+-------+
例如,根據(jù)上述給定的 Scores 表昨忆,你的查詢應該返回(按分數(shù)從高到低排列):

+-------+------+
| Score | Rank |
+-------+------+
| 4.00 | 1 |
| 4.00 | 1 |
| 3.85 | 2 |
| 3.65 | 3 |
| 3.65 | 3 |
| 3.50 | 4 |
+-------+------+

SELECT p1.Score,
(SELECT COUNT(DISTINCT p2.Score) FROM Scores p2 WHERE p2.Score >= p1.Score ) AS Rank
FROM Scores p1
ORDER BY p1.Score DESC

知識點:排名=分數(shù)比他高的人的人數(shù)

COUNT(DISTINCT p2.Score) FROM Scores p2 WHERE p2.Score >= p1.Score

180.連續(xù)出現(xiàn)的數(shù)字
編寫一個 SQL 查詢丁频,查找所有至少連續(xù)出現(xiàn)三次的數(shù)字。

+----+-----+
| Id | Num |
+----+-----+
| 1 | 1 |
| 2 | 1 |
| 3 | 1 |
| 4 | 2 |
| 5 | 1 |
| 6 | 2 |
| 7 | 2 |
+----+-----+
例如邑贴,給定上面的 Logs 表席里, 1 是唯一連續(xù)出現(xiàn)至少三次的數(shù)字。

+-----------------+
| ConsecutiveNums |
+-----------------+
| 1 |
+-----------------+

SELECT DISTINCT
    l1.Num AS ConsecutiveNums
FROM
    Logs l1,
    Logs l2,
    Logs l3
WHERE
    l1.Id = l2.Id - 1
    AND l2.Id = l3.Id - 1
    AND l1.Num = l2.Num
    AND l2.Num = l3.Num

知識點:連續(xù)=id連續(xù)拢驾,值相同奖磁。

181.收入超過經(jīng)理的員工
Employee 表包含所有員工,他們的經(jīng)理也屬于員工繁疤。每個員工都有一個 Id咖为,此外還有一列對應員工的經(jīng)理的 Id。

+----+-------+--------+-----------+
| Id | Name | Salary | ManagerId |
+----+-------+--------+-----------+
| 1 | Joe | 70000 | 3 |
| 2 | Henry | 80000 | 4 |
| 3 | Sam | 60000 | NULL |
| 4 | Max | 90000 | NULL |
+----+-------+--------+-----------+
給定 Employee 表稠腊,編寫一個 SQL 查詢躁染,該查詢可以獲取收入超過他們經(jīng)理的員工的姓名。在上面的表格中架忌,Joe 是唯一一個收入超過他的經(jīng)理的員工吞彤。

+----------+
| Employee |
+----------+
| Joe |
+----------+

SELECT a.Name AS Employee
FROM Employee a LEFT JOIN Employee b on (a.ManagerId = b.Id)
WHERE (a.Salary > b.Salary)

知識點:Employee表使用兩次。

  1. 查找重復的電子郵箱

編寫一個 SQL 查詢叹放,查找 Person 表中所有重復的電子郵箱饰恕。

示例:

+----+---------+
| Id | Email |
+----+---------+
| 1 | a@b.com |
| 2 | c@d.com |
| 3 | a@b.com |
+----+---------+
根據(jù)以上輸入,你的查詢應返回以下結(jié)果:

+---------+
| Email |
+---------+
| a@b.com |
+---------+

SELECT DISTINCT Email 
FROM Person
GROUP BY Email
HAVING COUNT(Email) > 1

知識點:Group by ....Having.....

  1. 從不訂購的客戶
    某網(wǎng)站包含兩個表井仰,Customers 表和 Orders 表埋嵌。編寫一個 SQL 查詢,找出所有從不訂購任何東西的客戶俱恶。

Customers 表:

+----+-------+
| Id | Name |
+----+-------+
| 1 | Joe |
| 2 | Henry |
| 3 | Sam |
| 4 | Max |
+----+-------+
Orders 表:

+----+------------+
| Id | CustomerId |
+----+------------+
| 1 | 3 |
| 2 | 1 |
+----+------------+
例如給定上述表格雹嗦,你的查詢應返回:

+-----------+
| Customers |
+-----------+
| Henry |
| Max |
+-----------+

SELECT C.Name AS Customers
FROM Customers C LEFT JOIN Orders O ON C.Id = O.CustomerId
WHERE O.CustomerId is null

知識點:左連接以后范舀,找不到與左表ID相同的記錄的名字就是沒有訂購過的用戶,注意用ON不能用where俐银。

197.上升的溫度
給定一個 Weather 表尿背,編寫一個 SQL 查詢,來查找與之前(昨天的)日期相比溫度更高的所有日期的 Id捶惜。

+---------+------------------+------------------+
| Id(INT) | RecordDate(DATE) | Temperature(INT) |
+---------+------------------+------------------+
| 1 | 2015-01-01 | 10 |
| 2 | 2015-01-02 | 25 |
| 3 | 2015-01-03 | 20 |
| 4 | 2015-01-04 | 30 |
+---------+------------------+------------------+
例如田藐,根據(jù)上述給定的 Weather 表格,返回如下 Id:

+----+
| Id |
+----+
| 2 |
| 4 |
+----+

SELECT a.ID
FROM Weather a
JOIN Weather b 
ON DATEDIFF(a.RecordDate,b.RecordDate) = 1 AND a.Temperature > b.Temperature

知識點:日期處理DATEDIFF

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吱七,一起剝皮案震驚了整個濱河市汽久,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌踊餐,老刑警劉巖景醇,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異吝岭,居然都是意外死亡三痰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進店門窜管,熙熙樓的掌柜王于貴愁眉苦臉地迎上來散劫,“玉大人,你說我怎么就攤上這事幕帆』癫” “怎么了?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵失乾,是天一觀的道長常熙。 經(jīng)常有香客問我,道長碱茁,這世上最難降的妖魔是什么裸卫? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮早芭,結(jié)果婚禮上彼城,老公的妹妹穿的比我還像新娘。我一直安慰自己退个,他們只是感情好,可當我...
    茶點故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布调炬。 她就那樣靜靜地躺著语盈,像睡著了一般。 火紅的嫁衣襯著肌膚如雪缰泡。 梳的紋絲不亂的頭發(fā)上刀荒,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天代嗤,我揣著相機與錄音,去河邊找鬼缠借。 笑死干毅,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的泼返。 我是一名探鬼主播硝逢,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼绅喉!你這毒婦竟也來了渠鸽?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤柴罐,失蹤者是張志新(化名)和其女友劉穎徽缚,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體革屠,經(jīng)...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡凿试,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了似芝。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片那婉。...
    茶點故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖国觉,靈堂內(nèi)的尸體忽然破棺而出吧恃,到底是詐尸還是另有隱情,我是刑警寧澤麻诀,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布痕寓,位于F島的核電站,受9級特大地震影響蝇闭,放射性物質(zhì)發(fā)生泄漏呻率。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一呻引、第九天 我趴在偏房一處隱蔽的房頂上張望礼仗。 院中可真熱鬧,春花似錦逻悠、人聲如沸元践。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽单旁。三九已至,卻和暖如春饥伊,著一層夾襖步出監(jiān)牢的瞬間象浑,已是汗流浹背蔫饰。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留愉豺,地道東北人篓吁。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像蚪拦,于是被迫代替她去往敵國和親杖剪。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,507評論 2 359

推薦閱讀更多精彩內(nèi)容