天池龙珠计划SQL训练营Task06打卡

Task06打卡

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

SELECT 
MDATA.*,CPER.INDIC_NAME_EN,CPER.VALUE,INSTAT.N_INCOME,INSTAT.T_COGS,INSTAT.T_REVENUE
FROM (
SELECT TICKER_SYMBOL,END_DATE,CLOSE_PRICE FROM `market data` WHERE TICKER_SYMBOL IN ('600383','600048')
	) MDATA
	
		LEFT JOIN(
			SELECT DISTINCT TICKER_SYMBOL,INDIC_NAME_EN,END_DATE,VALUE FROM `company operating` WHERE TICKER_SYMBOL IN ('600383','600048')
		) CPER ON MDATA.TICKER_SYMBOL = CPER.TICKER_SYMBOL AND MDATA.END_DATE = CPER.END_DATE
		
		LEFT JOIN(
			SELECT DISTINCT TICKER_SYMBOL,END_DATE,T_REVENUE,T_COGS,N_INCOME FROM `income statement` WHERE TICKER_SYMBOL IN ('600383','600048')
		) INSTAT ON MDATA.TICKER_SYMBOL = INSTAT.TICKER_SYMBOL AND MDATA.END_DATE = INSTAT.END_DATE
		
	ORDER BY MDATA.TICKER_SYMBOL,MDATA.END_DATE;

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

SELECT
	pH,
	`citric acid`,
	DENSE_RANK() OVER ( ORDER BY `citric acid` ) AS ranking
FROM
	`winequality-red` 
WHERE
	pH = 3.03;

3.使用Coupon Usage Data for O2O中的数据集《ccf_offline_stage1_test_revised.csv》,试分别找出在2016年7月期间,发放优惠券总金额最多和发放优惠券张数最多的商家。
这里只考虑满减的金额,不考虑打几折的优惠券。

发放优惠券总金额最多
SELECT 
	Merchant_id,SUM(SUBSTRING_INDEX(Discount_rate,':',-1)) Coupon_sum 
FROM ccf_offline_stage1_test_revised 
WHERE Date_received like '2016-07%' and Discount_rate not LIKE '0.%' 
GROUP BY Merchant_id 
ORDER BY Coupon_sum desc 
LIMIT 1;
发放优惠券张数最多的商家。
SELECT 
	Merchant_id,count(Coupon_id) Coupon_num 
FROM ccf_offline_stage1_test_revised 
WHERE Date_received like '2016-07%' 
GROUP BY Merchant_id
ORDER BY Coupon_num DESC 
LIMIT 1;


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

SELECT 
	currData.*,
	(currData.FianlValue - lastData.FianlValue) / lastData.FianlValue changeVal
 FROM (
	SELECT 
		PERIOD_DATE,MAX(DATA_VALUE) FianlValue 
	FROM `macro industry` 
	WHERE INDIC_ID = '2020101522' AND YEAR(PERIOD_DATE) = 2015 
	GROUP BY PERIOD_DATE 
	ORDER BY FianlValue DESC 
	LIMIT 1
) currData
 LEFT JOIN (
	SELECT PERIOD_DATE,
		MAX(DATA_VALUE) FianlValue
	FROM `macro industry`
	WHERE INDIC_ID = '2020101522' AND YEAR(PERIOD_DATE) = 2014
	GROUP BY PERIOD_DATE 
) lastData ON YEAR(currData.PERIOD_DATE) = YEAR(lastData.PERIOD_DATE) + 1 AND MONTH(currData.PERIOD_DATE) = MONTH(lastData.PERIOD_DATE);

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

线上总体优惠券弃用率为多少
SELECT 
	(SUM(Coupon_id IS NOT NULL AND Date is null) / SUM(Coupon_id IS NOT NULL)) as rate
FROM ccf_online_stage1_train 
WHERE  Date_received LIKE '2016-06%';

优惠券弃用率最高的商家
SELECT 
	Merchant_id,
	(SUM(Coupon_id IS NOT NULL AND Date is null) / SUM(Coupon_id IS NOT NULL)) as discard_rate
FROM ccf_online_stage1_train 
WHERE Date_received LIKE '2016-06%'
GROUP BY Merchant_id
ORDER BY discard_rate desc,SUM(Coupon_id IS NOT NULL AND Date is null) 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 rank 
FROM `winequality-white` 
WHERE pH = 3.63;

7.请使用A股上市公司季度营收预测中的数据集《Market Data.xlsx》中的sheet-DATA,
计算截止到2018年底,市值最大的三个行业是哪些?以及这三个行业里市值最大的三个公司是哪些?(每个行业找出前三大的公司,即一共要找出9个)

截止到2018年底,市值最大的三个行业是哪些
SELECT
	TYPE_NAME_CN,
	SUM( MARKET_VALUE ) '市值' 
FROM `market data` 
WHERE YEAR ( END_DATE ) = '2018-12-31' 
GROUP BY TYPE_NAME_CN 
ORDER BY SUM( MARKET_VALUE ) DESC 
LIMIT 3;
这三个行业里市值最大的三个公司是哪些?
SELECT
	CompanyData.TYPE_NAME_CN,
	CompanyData.TICKER_SYMBOL 
FROM( 
	SELECT 
		TYPE_NAME_CN, 
		TICKER_SYMBOL, 
		MARKET_VALUE, 
		ROW_NUMBER() OVER ( PARTITION BY TYPE_NAME_CN ORDER BY MARKET_VALUE ) AS CompanyRanking 
	FROM `market data` 
) CompanyData
LEFT JOIN ( 
	SELECT 
		TYPE_NAME_CN, SUM( MARKET_VALUE ) 
	FROM `market data` WHERE YEAR ( END_DATE ) = '2018-12-31' 
	GROUP BY TYPE_NAME_CN 
	ORDER BY SUM( MARKET_VALUE ) DESC 
	LIMIT 3 
) top3Type ON CompanyData.TYPE_NAME_CN = top3Type.TYPE_NAME_CN 
WHERE CompanyRanking <= 3 AND top3Type.TYPE_NAME_CN IS NOT NULL;


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

SELECT 
	User_id,SUM(T.used_coupon) used_times
FROM(
	SELECT 
		User_id,count(*) as used_coupon
	FROM ccf_online_stage1_train 
	WHERE  Coupon_id IS NOT NULL AND Date LIKE '2016-06%'
	GROUP BY User_id

	UNION ALL

	SELECT 
		User_id,count(*) as used_coupon
	FROM ccf_offline_stage1_train 
	WHERE  Coupon_id IS NOT NULL AND Date LIKE '201606%'
	GROUP BY User_id
) as T GROUP BY T.User_id
ORDER BY used_times 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.《ccf_offline_stage1_train.csv》,试找出在2016年6月期间,线上线下累计被使用优惠券满减最多的前3名商家。

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

SELECT 
	T.Merchant_id,SUM(T.sub_amount) sub_amount
FROM(
	SELECT 
		Merchant_id,SUM(SUBSTRING_INDEX(Discount_rate,':',-1)) as sub_amount
	FROM ccf_online_stage1_train 
	WHERE  Coupon_id IS NOT NULL AND Date LIKE '2016-06%' AND Discount_rate != 'fixed' and Discount_rate not like '0.%'
	GROUP BY Merchant_id

	UNION ALL

	SELECT 
		Merchant_id,SUM(SUBSTRING_INDEX(Discount_rate,':',-1)) as sub_amount
	FROM ccf_offline_stage1_train 
	WHERE  Coupon_id IS NOT NULL AND Date LIKE '201606%' AND Discount_rate != 'fixed' and Discount_rate not like '0.%'
	GROUP BY Merchant_id
) as T
GROUP BY T.Merchant_id
ORDER BY sub_amount desc
LIMIT 1;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值