阿里云AI训练营-SQL基础6:测试题

下载相关创建表格和插入数据脚本

这里为了方便大家,数据脚本已经给大家准备好啦。
点击下方链接直接下载
创建数据表脚本:http://tianchi-media.oss-cn-beijing.aliyuncs.com/dragonball/SQL/create_table.sql
插入数据脚本:http://tianchi-media.oss-cn-beijing.aliyuncs.com/dragonball/SQL/data.zip

大家下载好脚本后,先在MySQL环境中运行create_table.sql脚本,创建数据表,然后解压下载好的data.zip,解压后目录如下:

8-10ccf_offline_stage1_train.sql
6-winequality-white.sql
5-8-10ccf_online_stage1_train.sql
4-macro industry.sql
3-ccf_offline_stage1_test_revised.sql
2-winequality-red.sql
1-9income statement.sql
1-9company operating.sql
1-7market data.sql

脚本文件名前面的序号表示用到该数据集的题目序号,例如1-7market data.sql表示第1题和第7题用到了该数据集。
同样的,这里给大家的也是sql脚本,里面是插入数据的语句,大家只需打开后在MySQL环境中运行即可将数据导入到数据表中。

练习题1:

数据来源:数据集-阿里云天池

请使用A股上市公司季度营收预测数据集《Income Statement.xls》和《Company Operating.xlsx》和《Market Data.xlsx》,以Market Data为主表,将三张表中的TICKER_SYMBOL为600383和600048的信息合并在一起。只需要显示以下字段。

表名字段名
Income StatementTICKER_SYMBOL
Income StatementEND_DATE
Income StatementT_REVENUE
Income StatementT_COGS
Income StatementN_INCOME
Market DataTICKER_SYMBOL
Market DataEND_DATE_
Market DataCLOSE_PRICE
Company OperatingTICKER_SYMBOL
Company OperatingINDIC_NAME_EN
Company OperatingEND_DATE
Company OperatingVALUE

结果:

select m.TICKER_SYMBOL,m.END_DATE,m.CLOSE_PRICE,i.*,c.* from (SELECT TICKER_SYMBOL,END_DATE,CLOSE_PRICE from `market data` where TICKER_SYMBOL in ('600383','600048')) as m
left JOIN (select TICKER_SYMBOL,END_DATE,T_REVENUE,T_COGS,N_INCOME from `income statement` where TICKER_SYMBOL in ('600383','600048')) as i on i.TICKER_SYMBOL=m.TICKER_SYMBOL
left JOIN (SELECT TICKER_SYMBOL,INDIC_NAME_EN,END_DATE,`VALUE` from `company operating` where TICKER_SYMBOL in ('600383','600048')) as c on c.TICKER_SYMBOL=m.TICKER_SYMBOL 

练习题2:

数据来源:数据集-阿里云天池

请使用 Wine Quality Data 数据集《winequality-red.csv》,找出 pH=3.03的所有红葡萄酒,然后,对其 citric acid 进行中式排名(相同排名的下一个名次应该是下一个连续的整数值。换句话说,名次之间不应该有“间隔”)

结果:
 

SELECT pH,`citric acid`,DENSE_RANK() OVER (ORDER BY `citric acid`) as dense_rank 
from `winequality-red`
WHERE pH=3.03;

练习题3:

数据来源:天池新人实战赛o2o优惠券使用预测赛题与数据-天池大赛-阿里云天池

使用Coupon Usage Data for O2O中的数据集《ccf_offline_stage1_test_revised.csv》,试分别找出在2016年7月期间,发放优惠券总金额最多和发放优惠券张数最多的商家。

这里只考虑满减的金额,不考虑打几折的优惠券。

结果:1、发放优惠券总金额最多的商家:

SELECT Merchant_id,
       SUM(SUBSTRING_INDEX(Discount_rate,':',-1)) as Amount
from ccf_offline_stage1_test_revised
WHERE Date_received>='2016-07-01' AND Date_received<='2016-07-31'
GROUP BY Merchant_id 
ORDER BY Amount desc
limit 1

    2、发放优惠券张数最多的商家:

SELECT Merchant_id,count(0) as num
from ccf_offline_stage1_test_revised
WHERE Date_received>='2016-07-01' AND Date_received<='2016-07-31'
GROUP BY Merchant_id 
ORDER BY num desc
limit 1

练习题4:

数据来源:数据集-阿里云天池

请使用A股上市公司季度营收预测中的数据集《Macro&Industry.xlsx》中的sheet-INDIC_DATA,请计算全社会用电量:第一产业:当月值在2015年用电最高峰是发生在哪月?并且相比去年同期增长/减少了多少个百分比?

结果:1、2015年用电最高峰是发生在哪月?

SELECT PERIOD_DATE,MAX(DATA_VALUE) AS maxv
from `macro industry`
WHERE indic_id='2020101522' AND PERIOD_DATE>='2015-01-01' AND PERIOD_DATE<='2015-12-31'
GROUP BY PERIOD_DATE
ORDER BY maxv desc
limit 1;

2、相比去年同期增长/减少了多少个百分比?

select 
(SELECT DATA_VALUE from `macro industry`
where PERIOD_DATE='2015-08-31' and indic_id='2020101522')/(SELECT DATA_VALUE from `macro industry`
where PERIOD_DATE='2014-08-31' and indic_id='2020101522') as addv
from `macro industry`
limit 1;

练习题5:

数据来源:天池新人实战赛o2o优惠券使用预测赛题与数据-天池大赛-阿里云天池

使用Coupon Usage Data for O2O中的数据集《ccf_online_stage1_train.csv》,试统计在2016年6月期间,线上总体优惠券弃用率为多少?并找出优惠券弃用率最高的商家。

弃用率 = 被领券但未使用的优惠券张数 / 总的被领取优惠券张数

结果:2016年6月期间,线上总体优惠券弃用率为多少?

select SUM(CASE WHEN Date_received is not NULL AND Date IS NULL THEN 1 ELSE 0 END)/ 
       SUM(CASE WHEN Date_received is not NULL THEN 1 ELSE 0 END)
from ccf_offline_stage1_train
WHERE Date_received BETWEEN '2016-01-01' AND '2016-06-30';

    优惠券弃用率最高的商家?

select Merchant_id,SUM(CASE WHEN Date_received is not NULL AND Date IS NULL THEN 1 ELSE 0 END)/ 
       SUM(CASE WHEN Date_received is not NULL THEN 1 ELSE 0 END) as droped
from ccf_offline_stage1_train
where Date_received BETWEEN '2016-06-01' AND '2016-06-30'
GROUP BY Merchant_id
ORDER BY droped desc
limit 1;

练习题6:

数据来源:数据集-阿里云天池

请使用 Wine Quality Data 数据集《winequality-white.csv》,找出 pH=3.63的所有白葡萄酒,然后,对其 residual sugar 量进行英式排名(非连续的排名)

结果:

SELECT pH,`residual sugar`,RANK() OVER (ORDER BY `residual sugar`) AS RK
from `winequality-white`
WHERE pH=3.63;

练习题7:

数据来源:数据集-阿里云天池

请使用A股上市公司季度营收预测中的数据集《Market Data.xlsx》中的sheet-DATA,

计算截止到2018年底,市值最大的三个行业是哪些?以及这三个行业里市值最大的三个公司是哪些?(每个行业找出前三大的公司,即一共要找出9个)

结果:1、计算截止到2018年底,市值最大的三个行业是哪些?

SELECT TYPE_NAME_CN,MAX(MARKET_VALUE) as mm
from `market data`
WHERE YEAR(END_DATE)=2018
GROUP BY TYPE_NAME_CN
ORDER BY mm
 limit 3;

    2、最大的三个公司是哪些?

SELECT * FROM
(
SELECT TYPE_NAME_CN,MAX(MARKET_VALUE) as mm
from `market data`
WHERE YEAR(END_DATE)=2018
GROUP BY TYPE_NAME_CN
ORDER BY mm
 limit 3
) as ind3
LEFT JOIN
(
SELECT TYPE_NAME_CN,MARKET_VALUE,ROW_NUMBER() OVER (PARTITION BY TYPE_NAME_CN ORDER BY MARKET_VALUE) AS Comrank
from `market data`
WHERE YEAR(END_DATE)=2018
GROUP BY TYPE_NAME_CN
ORDER BY mm
 limit 3
) as com3
on ind3.TYPE_NAME_CN=com3.TYPE_NAME_CN
WHERE com3.Comrank<=3

练习题8:

数据来源:天池新人实战赛o2o优惠券使用预测赛题与数据-天池大赛-阿里云天池

使用Coupon Usage Data for O2O中的数据集《ccf_online_stage1_train.csv》和《ccf_offline_stage1_train.csv》,试找出在2016年6月期间,线上线下累计优惠券使用次数最多的顾客。

结果:

select Merchant_id,SUM(CASE WHEN Date_received IS NOT NULL AND Date IS NOT NULL THEN 1 ELSE 0 END) as used
from ccf_offline_stage1_train
where Date_received BETWEEN '2016-06-01' AND '2016-06-30'
GROUP BY User_id
ORDER BY used desc
limit 1;

练习题9:

数据来源:数据集-阿里云天池

请使用A股上市公司季度营收预测数据集《Income Statement.xls》中的sheet-General Business和《Company Operating.xlsx》中的sheet-EN。

找出在数据集所有年份中,按季度统计,白云机场旅客吞吐量最高的那一季度对应的净利润是多少?(注意,是单季度对应的净利润,非累计净利润。)

结果:

SELECT * FROM 
(SELECT TICKER_SYMBOL, YEAR(END_DATE) Year, QUARTER(END_DATE) QUARTER, SUM(VALUE) Amount 
FROM `company operating` 
WHERE INDIC_NAME_EN = 'Baiyun Airport:Passenger throughput' 
GROUP BY TICKER_SYMBOL,YEAR(END_DATE),QUARTER(END_DATE) 
ORDER BY SUM(VALUE) DESC LIMIT 1 ) BaseData 
LEFT JOIN 
(SELECT TICKER_SYMBOL, YEAR(END_DATE) Year, QUARTER(END_DATE) QUARTER, SUM(N_INCOME) Amount 
FROM `income statement` 
GROUP BY TICKER_SYMBOL,YEAR(END_DATE),QUARTER(END_DATE) ) Income 
ON BaseData.TICKER_SYMBOL = Income.TICKER_SYMBOL AND BaseData.Year = Income.Year AND BaseData.QUARTER = Income.QUARTER

练习题10:

数据来源:天池新人实战赛o2o优惠券使用预测赛题与数据-天池大赛-阿里云天池

使用Coupon Usage Data for O2O中的数据集《ccf_online_stage1_train.csv》和《ccf_offline_stage1_train.csv》,试找出在2016年6月期间,线上线下累计被使用优惠券满减最多的前3名商家。

比如商家A,消费者A在其中使用了一张200减50的,消费者B使用了一张30减1的,那么商家A累计被使用优惠券满减51元。

结果:

SELECT Merchant_id, SUM(discount_amount) discount_amount 
FROM 
(SELECT Merchant_id, SUM(SUBSTRING_INDEX(`Discount_rate`,':',-1)) AS discount_amount 
FROM `ccf_online_stage1_train` 
WHERE (Date != 'null' AND Coupon_id != 'null') AND (LEFT(DATE,4)=2016 ) AND MID(DATE,5,2) = '06' 
GROUP BY Merchant_id 
UNION ALL 
SELECT Merchant_id, SUM(SUBSTRING_INDEX(`Discount_rate`,':',-1)) AS discount_amount 
FROM `ccf_offline_stage1_train` 
WHERE (Date != 'null' AND Coupon_id != 'null') AND (LEFT(DATE,4)=2016 ) AND MID(DATE,5,2) = '06' 
GROUP BY Merchant_id ) BaseData
GROUP BY Merchant_id
ORDER BY  SUM(discount_amount) DESC
LIMIT 1;

本教程相关练习题答案可以在天池官方公众号:天池大数据科研平台 回复:SQL训练营 获取。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值