抱歉,您的浏览器无法访问本站

本页面需要浏览器支持(启用)JavaScript


了解详情 >

blaire

👩🏻‍💻星洲小课堂 SinClass

image

猴子SQL

1. SQL

SQL Leetcode Plan

1.1 IF / GROUP BY

1.1 1699. Number of Calls Between Two Persons

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
SELECT 
person1,person2,
count(*) call_count,
sum(duration) total_duration
FROM
(
SELECT
IF(from_id>to_id, to_id, from_id) person1,
IF(from_id>to_id,from_id,to_id) person2,
duration
FROM
calls
) c
GROUP BY
person1, person2

1.2 BETWEEN sdate AND edate

1.2 1251. 平均售价 average_price

knowleage: BETWEEN start_date AND end_date

1
2
3
4
5
6
7
8
9
10
11
12
13
SELECT
product_id,
Round(SUM(sales) / SUM(units), 2) AS average_price
FROM (
SELECT
Prices.product_id AS product_id,
Prices.price * UnitsSold.units AS sales,
UnitsSold.units AS units
FROM
Prices JOIN UnitsSold ON Prices.product_id = UnitsSold.product_id
WHERE UnitsSold.purchase_date BETWEEN Prices.start_date AND Prices.end_date
) T
GROUP BY product_id

1.3 SUM / GROUP BY

1.3 1571. Warehouse Manager

知识: SUM / GROUP BY

1
2
3
4
5
6
7
8
9
10
SELECT 
w.name WAREHOUSE_NAME,
SUM(p.Width * p.Length * p.Height * w.units) VOLUME
FROM
warehouse w
LEFT JOIN
products p
ON
w.product_id = p.product_id
GROUP BY w.name;

1.4 SUM + CASE WHEN

1.4 1445. Apples & Oranges

知识: SUM / CASE WHEN / GROUP BY / ORDER BY

1
2
3
4
5
6
SELECT 
sale_date,
SUM(CASE WHEN fruit='apples' THEN sold_num ELSE -sold_num END) AS diff
FROM sales
GROUP BY sale_date
ORDER BY sale_date;

1.5 COUNT / SUM / IF

1.5 1193. Monthly Transactions I

理清逻辑, 冷静分析

知识:

  1. count(1)与count(*)得到的结果一致,包含null值。
  2. count(字段)不计算null值
  3. count(null)结果恒为0

知识: DATE_FORMAT / COUNT / SUM / IF / GROUP BY

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
SELECT 
DATE_FORMAT(trans_date, '%Y-%m') AS month,
country,
COUNT(*) AS trans_count,
COUNT(
IF(state = 'approved', 1, NULL)
) AS approved_count,
SUM(amount) AS trans_total_amount,
SUM(
IF(state = 'approved', amount, 0)
) AS approved_total_amount
FROM
Transactions
GROUP BY
month,
country

1.6 round(num, 2)

1.6 1633. Percentage of Users Attended a Contest

知识: round(num, 2) / 子查询在SELECT里 / GROUP BY [子查询在SELECT里 MYSQL 支持, Hive/Spark 不一定支持]

1
2
3
4
5
6
select 
contest_id,
round(count(user_id) / (select count(1) from Users) * 100, 2) as percentage
from Register
group by contest_id
order by percentage desc,contest_id

1.7 1173. Immediate Food Delivery I

1
2
3
4
5
6
select 
round (
sum(order_date = customer_pref_delivery_date) / count(*) * 100,
2
) as immediate_percentage
from Delivery

1.8 AVG(rating<3) / SUM IF

1.8 1211. Queries Quality and Percentage

知识:自从学会了AVG AVG(rating < 3) = AVG(条件)相当于sum(if(条件,1,0))/count(全体)

使用bool条件将多个样本判断为0和1,多个0和多个1的平均值就是1在整体中的比例,也即满足条件的样本在整体中的比例。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
SELECT 
query_name,
ROUND(AVG(rating/position), 2) quality,
ROUND(SUM(IF(rating < 3, 1, 0)) * 100 / COUNT(*), 2) poor_query_percentage
FROM Queries
GROUP BY query_name

==

SELECT query_name
, round(AVG(rating / position), 2) AS quality
, round(100 * AVG(rating < 3), 2) AS poor_query_percentage
FROM Queries
GROUP BY query_name;

1.9 DATE_FORMAT / NOT IN

1.9 1607. Sellers With No Sales

1
2
3
4
5
6
7
8
9
10
11
-- DATE_FORMAT / WHERE NOT IN

SELECT
seller_name AS SELLER_NAME
FROM
Seller
WHERE
Seller.seller_id NOT IN (
SELECT DISTINCT seller_id AS id FROM Orders WHERE DATE_FORMAT(sale_date, "%Y") = 2020
)
ORDER BY SELLER_NAME;

1.10 Group by + Having

619. Biggest Single Number

having只用于group by分组统计语句

1
2
3
4
5
6
7
8
9
10
11
select 
max(num) as num
from
(
select
num
from
MyNumbers
group by num
having count(num) = 1
) t

1.11 dense_rank() over (part

1112. Highest Grade For Each Student

1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 窗口
select
student_id,
course_id,
grade
from
(
select
*,
dense_rank() over (partition by student_id order by grade desc, course_id) rk
from enrollments
) t
where
rk=1

1.12 Having+SUM(IF / Count(IF)

1398. Customers Who Bought Products A and B but Not C

1
2
3
4
5
6
7
8
9
10
select 
o.customer_id customer_id,
c.customer_name customer_name
from
orders o JOIN customers c ON o.customer_id = c.customer_id
group by o.customer_id
having
SUM(IF(o.product_name='A',1,0)) > 0
AND SUM(IF(o.product_name='B',1,0)) > 0
AND SUM(IF(o.product_name='C',1,0))=0

BigData

Reference

Comments