【数分面试题】SQL专项题目记录二

这篇博客整理了SQL面试中的一些专项题目,包括行列转换、条件选择、当前日期判断、重复记录处理等。涉及到的关键技术有CASE WHEN、PIVOT、UNPIVOT、GROUP BY、HAVING、DISTINCT、AVG、SUM、COUNT、MIN、窗口函数等,同时也提到了Oracle的ROLLUP和CUBE函数。
摘要由CSDN通过智能技术生成

https://www.cnblogs.com/guxia/p/7878657.html 大佬的笔记

  1. 行列转换
    在这里插入图片描述
    考点:case when
    注意: pivot纵表转横表,unpivot 横表转纵表
    https://blog.csdn.net/lch_2016/article/details/81947448
    SELECT date, sum( CASE result WHEN '胜' THEN 1 ELSE 0 END ) AS '胜', sum( CASE result WHEN '负' THEN 1 ELSE 0 END ) AS '负' FROM shengfu GROUP BY date

2.表中有A B C三列,用SQL语句实现:
第一列,当A列大于B列选择A列否则选择B列,第二列,当B列大于C列选择B列否则C列
考点:case when

create table compare 
(
   A int,
   B int,
   C int
)

insert into compare values(10,20,30);
insert into compare values(20,30,10);
insert into compare values(30,10,20);
insert into compare values(10,20,30);

select * from compare
select (case when a>b and a>c then a
			 when b>a and b>c then b
			 else c
			 end)
from compare
  1. 表名test_table中有一个date型字段create_date,取出所有create_date为今天得记录
    考点:curdate(), now()
select date_format(now(),'%y-%m-%d') as date

select * from test_table where crate_date = curdate()

4.在这里插入图片描述
考点:case when,分组分类

select
(case when 语文>=80 then ‘优秀’
when 语文>=60 then ‘及格’
else ‘不及格’) as 语文,
(case when 数学>=80 then ‘优秀’
when 数学>=60 then ‘及格’
else ‘不及格’) as 数学,
(case when 英语>=80 then ‘优秀’
when 英语>=60 then ‘及格’
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值