当前位置: 首页 > news >正文

做t恤的网站德国和俄罗斯和做视频网站

做t恤的网站,德国和俄罗斯和做视频网站,红和蓝的企业网站设计,网站seo推广优化教程大家好,我是空空star,本篇带大家了解一道中等的力扣sql练习题。 文章目录前言一、题目:176. 第二高的薪水二、解题1.正确示范①提交SQL运行结果2.正确示范②提交SQL运行结果3.正确示范③提交SQL运行结果4.正确示范④提交SQL运行结果5.其他总结…

大家好,我是空空star,本篇带大家了解一道中等的力扣sql练习题。

文章目录

  • 前言
  • 一、题目:176. 第二高的薪水
  • 二、解题
    • 1.正确示范①
      • 提交SQL
      • 运行结果
    • 2.正确示范②
      • 提交SQL
      • 运行结果
    • 3.正确示范③
      • 提交SQL
      • 运行结果
    • 4.正确示范④
      • 提交SQL
      • 运行结果
    • 5.其他
  • 总结


前言


一、题目:176. 第二高的薪水

Employee 表:

+-------------+------+
| Column Name | Type |
+-------------+------+
| id          | int  |
| salary      | int  |
+-------------+------+
id 是这个表的主键。
表的每一行包含员工的工资信息。

编写一个 SQL 查询,获取并返回 Employee 表中第二高的薪水 。如果不存在第二高的薪水,查询应该返回 null 。

查询结果如下例所示。

示例1:

输入:
Employee 表:
+----+--------+
| id | salary |
+----+--------+
| 1  | 100    |
| 2  | 200    |
| 3  | 300    |
+----+--------+
输出:
+---------------------+
| SecondHighestSalary |
+---------------------+
| 200                 |
+---------------------+

示例 2:

输入:
Employee 表:
+----+--------+
| id | salary |
+----+--------+
| 1  | 100    |
+----+--------+
输出:
+---------------------+
| SecondHighestSalary |
+---------------------+
| null                |
+---------------------+

二、解题

1.正确示范①

提交SQL

select salary SecondHighestSalary from(select salary,row_number() over(order by salary desc ) colfrom(select salaryfrom Employee unionselect null) u
) u 
where col=2;

运行结果

2.正确示范②

提交SQL

select salary SecondHighestSalary from(select salary,rank() over(order by salary desc ) colfrom(select salaryfrom Employee unionselect null) u
) u 
where col=2;

运行结果

3.正确示范③

提交SQL

select salary SecondHighestSalary from(select salary,dense_rank() over(order by salary desc ) colfrom(select salaryfrom Employee unionselect null) u
) u 
where col=2;

运行结果

4.正确示范④

提交SQL

select ifnull(
(select distinct salary from Employee
order by salary desc limit 1 offset 1),
null) as SecondHighestSalary;

运行结果

5.其他


总结

正确示范①思路:
考虑到工资可能重复以及不存在第二高的薪水时查询应该返回 null ,
我们做如下处理:
select salary from Employee union select null
然后再采用row_number() over(order by salary desc ) col,限定col=2;
正确示范②思路:
考虑到工资可能重复以及不存在第二高的薪水时查询应该返回 null ,
我们做如下处理:
select salary from Employee union select null
然后再采用rank() over(order by salary desc ) col,限定col=2;
正确示范③思路:
考虑到工资可能重复以及不存在第二高的薪水时查询应该返回 null ,
我们做如下处理:
select salary from Employee union select null
然后再采用dense_rank() over(order by salary desc ) col,限定col=2;
正确示范④思路:
对工资通过distinct去重后,
通过 order by salary desc按工资降序,
通过limit 1 offset 1跳过1条数据,读取1条数据,
再通过ifnull(表达式,null)做空时返回null处理。
知识点:
row_number:顺序排序;
rank:并列排序,会跳过重复的序号,比如序号为1、1、3;
dense_rank:并列排序,不会跳过重复的序号,比如序号为1、1、2。
limit y 表示: 读取前y 条数据
limit x, y 表示: 跳过 x 条数据,读取 y 条数据
limit y offset x 表示: 跳过 x 条数据,读取 y 条数据

http://www.yayakq.cn/news/821565/

相关文章:

  • 个人建设网站需要什么证件吗软件定制开发
  • 自己买域名可以做网站吗国外优秀网站欣赏
  • 滨州网站建设九鲁网站建设课程设计心得体会
  • 网站开发中期检查我做网站编辑写文章很慢怎么办
  • 太仓网站建设国外比较有名的设计工作室网站
  • icp网站成品网站w灬源码1688永久网站
  • 接单网站开发aso优化分析
  • 建设电商网站多少钱seo综合查询平台官网
  • 正规招聘网站有哪些wordpress 主题和搭建
  • php网站开发如何实现删除功能yandex推广
  • 磐安县住和城乡建设局网站宁波品牌网站推广优化
  • 建设网站的基本技术小红书关键词检测
  • 南宁著名的网站网页设计心得体会800字
  • 九江专业制作网站小程序绿色食品网站源码
  • 网站建设与维护心得体会北京最大的广告制作公司
  • php网站开发报价购物网站开发的背景
  • 网站服务器建设的三种方法网站建设存在不足
  • ssp媒体服怎样做网站七牛云可以做网站的存储空间吗
  • 多媒体网站建设wordpress 添加导航
  • 图书馆评估定级关于网站建设标准网推是什么意思
  • 网页设计资料下载网站贵阳建设企业网站
  • 西安专业网站排名优化宁波男科医院哪家比较好
  • html5video网站如何利用dw建设网站
  • 东莞网站seo技术今天安阳最新消息
  • 怎样弄免费网站济南小程序定制
  • aspnet网站开发实例教程pdf广西壮族自治区官方网
  • 设计开发网站深圳装饰装修公司
  • 网站建设有什么岗位职责手机优化电池充电要开吗
  • 镇江网站搜索优化生产erp软件
  • wordpress备份整站初级前端工程师工资