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表使用兩次。
- 查找重復的電子郵箱
編寫一個 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.....
- 從不訂購的客戶
某網(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