【SQL50】day 2

目录

1.每位经理的下属员工数量

2.员工的直属部门

3.判断三角形

4.上级经理已离职的公司员工

5.换座位

6.电影评分

7.修复表中的名字

8.患某种疾病的患者

9.删除重复的电子邮箱

1.每位经理的下属员工数量

sql 复制代码
# Write your MySQL query statement below
#e1是经理,e2是员工
select e1.employee_id,e1.name,count(e2.employee_id) as reports_count,round(avg(e2.age)) as average_age
from Employees e1
join Employees e2
on e1.employee_id=e2.reports_to
group by e1.employee_id,e1.name
order by e1.employee_id;

2.员工的直属部门

sql 复制代码
# Write your MySQL query statement below
select employee_id,if(count(department_id)=1,department_id,
            max(case primary_flag when 'Y' then department_id end)) as department_id
from Employee
group by employee_id

3.判断三角形

sql 复制代码
# Write your MySQL query statement below
select x,y,z,
      case
          when x+y>z and x+z>y and y+z>x then 'Yes'
          else 'No'
      end as triangle
from Triangle;

4.上级经理已离职的公司员工

sql 复制代码
# Write your MySQL query statement below
#子查询就是查询套查询
select employee_id
from Employees 
where salary<30000
and manager_id not in (select employee_id from Employees)
order by employee_id

5.换座位

sql 复制代码
# Write your MySQL query statement below
select s1.id as id,
      #逻辑:如果没有下一位,且当前是奇数,不改动;奇数取下一位的值,偶数取上一位的值
      if(s2.id is null && s1.id%2=1,s1.student,if(s1.id%2=1,s2.student,s3.student)) as student
from Seat s1
left join Seat s2 on s2.id=s1.id+1
left join Seat s3 on s3.id=s1.id-1
order by id

6.电影评分

sql 复制代码
# Write your MySQL query statement below
#查找用户
(select u.name as results
from Users u
left join MovieRating mr 
on u.user_id=mr.user_id
group by u.user_id
order by count(*) desc,name asc
limit 1
)
#查找电影
union all
(
select title as results
from Movies m
left join MovieRating mr
on m.movie_id=mr.movie_id and year(mr.created_at)=2020 and month(mr.created_at)=2
group by mr.movie_id
order by avg(mr.rating) desc,title asc
limit 1
)

7.修复表中的名字

sql 复制代码
# Write your MySQL query statement below
#使用substring分割字符,使用upper,lower大小写,使用concat连接
select user_id,concat(upper(substring(name,1,1)),lower(substring(name,2))) name
from Users
order by user_id

8.患某种疾病的患者

sql 复制代码
# Write your MySQL query statement below
select *
from Patients
where conditions regexp '^DIAB1|\\sDIAB1'

9.删除重复的电子邮箱

sql 复制代码
# Write your MySQL query statement below
#delete删除
delete p1
from Person p1,Person p2
where p1.email=p2.email and p1.id>p2.id
相关推荐
si莉亚9 分钟前
ROS2安装EVO工具包
linux·开发语言·c++·开源
清心歌17 分钟前
CopyOnWriteArrayList 实现原理
java·开发语言
qinian_ztc38 分钟前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
良木生香41 分钟前
【C++初阶】C++入门相关知识(2):输入输出 & 缺省参数 & 函数重载
开发语言·c++
忘梓.42 分钟前
墨色规则与血色节点:C++红黑树设计与实现探秘
java·开发语言·c++
hhh3u3u3u42 分钟前
Visual C++ 6.0中文版安装包下载教程及win11安装教程
java·c语言·开发语言·c++·python·c#·vc-1
星河耀银海1 小时前
C++ 模板进阶:特化、萃取与可变参数模板
java·开发语言·c++
cccccc语言我来了1 小时前
【C++---unordered_set/map底层封装】个不拘一格的集合。它不似有序集合那般循规蹈矩,而是以一种洒脱不羁的方式,将元素们随意地散落其中。每一个元素都是独一无二的。
开发语言·c++·哈希算法
Zfox_1 小时前
C++ IO流全解析:标准库中的数据处理与文件读写艺术
开发语言·c++
加号31 小时前
【C#】实现沃德普线光控制器通信控制(附完整源码)
开发语言·c#