在牛客网刷题day2——SQL6&&SQL7&&SQL8 [数据库--“查找所有员工入职时候的薪水情况“]

参考:https://blog.csdn.net/mathew_leung/article/details/83147170 && https://blog.csdn.net/qq_24654501/article/details/107239348

【本片记录8.7日错题】

牛客网 SQL6

题目描述:

查找所有员工入职时候的薪水情况,给出emp_no以及salary, 并按照emp_no进行逆序
CREATE TABLE employees (
emp_no int(11) NOT NULL,
birth_date date NOT NULL,
first_name varchar(14) NOT NULL,
last_name varchar(16) NOT NULL,
gender char(1) NOT NULL,
hire_date date NOT NULL,
PRIMARY KEY (emp_no));
CREATE TABLE salaries (
emp_no int(11) NOT NULL,
salary int(11) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL,
PRIMARY KEY (emp_no,from_date));

解题方法:

方法一:

select e.emp_no,s.salary from employees e left join salaries s on 
e.emp_no = s.emp_no and e.hire_date = s.from_date 
order by e.emp_no desc;

解释:
Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。
它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。
注意:group by 是先排序后分组;
order by :分组
desc : 降序(数字从大到小排列、日期从目前到过去排列)

方法二:

SELECT emp_no, salary
FROM salaries
GROUP BY emp_no
HAVING MIN(from_date)
ORDER BY emp_no DESC;

解释:
【获取salaries中from_data中最小的对应的salary和emp_no,因为salaries可能涨薪,所以这张表一个员工可能有多条记录。】
HAVING 子句对 GROUP BY 子句设置条件的方式与 WHERE 和 SELECT 的交互方式类似。WHERE 搜索条件在进行分组操作之前应用;而 HAVING 搜索条件在进行分组操作之后应用。HAVING 语法与 WHERE 语法类似,但 HAVING 可以包含聚合函数。HAVING 子句可以引用选择列表中显示的任意项。因为where子句不可以配合group by 子句使用,所以在使用group by时使用having子句对分组进行限制


牛客网—— SQL7–“查找薪水变动超过15次的员工号emp_no以及其对应的变动次数t”

题目描述:

查找薪水变动超过15次的员工号emp_no以及其对应的变动次数t
CREATE TABLE `salaries` (
`emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));

解析:
题目真正意思是出现一次emp_no计数一次涨幅。
(感觉题目说的有些歧义,题目的意思是出现一次emp_no就计数一次涨幅,实际中有些工资是不涨的,有些是降的。既然要求这么歧义的干,那就干下去吧)

解题:

select emp_no,count(emp_no) as  t from salaries group by emp_no having t > 15;

这里有几点需要注意:
1、用COUNT()函数和GROUP BY语句可以统计同一emp_no值的记录条数
2、根据题意,输出的涨幅次数为t,故用AS语句将COUNT(emp_no)的值转换为t
【as 可以省略】
3、由于WHERE后不可跟COUNT()函数,故用HAVING语句来限定t>15的条件


SQL-8 ——找出所有员工当前(to_date=‘9999-01-01’)具体的薪水salary情况,对于相同的薪水只显示一次,并按照逆序显示

题目描述

找出所有员工当前(to_date='9999-01-01')具体的薪水salary情况,对于相同的薪水只显示一次,并按照逆序显示
CREATE TABLE `salaries` (
`emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));

思路: 在查找中 使用不重复的应该用distinct (而不是unique 约束)

有两种方式 distinct 和group

解题:

方法一:
select distinct salary from salaries
    where to_date='9999-01-01'
    order by salary desc
  
方法二:
select  salary from salaries
    where to_date='9999-01-01'
    group by salary
    order by salary desc

1、数据量较大时,重复数据占比比较高时 group by 效率略好于distinct

2、重复数据占比较少时,用distinct的性能会优于group by


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值