IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 随笔记录力扣上的数据库题 -> 正文阅读

[大数据]随笔记录力扣上的数据库题

?SQL题 中等题型 工具PL/SQL?

176.第二高的薪水一个薪水表(id,salary)SQL查询返回第二高的薪水,如果不存在第二高的薪水,查询返回null

用nvl做一个空值判断 我们加上select * from dual 语句 2.Oracle 我们从row_number() dense_rank()函数中选一个,这里我们选用dense_rank() 3.考虑到出现重复的salary 我们要在salary 前加一个聚合函数max。

select nvl(
        (select 
            max(salary)
        from 
            (select salary,dense_rank() over(order by salary desc) n from employee)
        where n=2)
       ,null) as secondhighestsalary
from dual;

177.第N高的薪水薪水表(id,salary)获取表中第n高的薪水

?写一个功能实现 create function begin end?

create function getnthhighestsalary(
n in number) 
return number is result number;
begin
    select 
        max(nvl(salary,null)) into result 
    from
        (select salary,dense_rank() over(order by salary desc) p from employee)
    where
        p = N;
    return result;
end;

178.分数排名分数相同则排名相同名次之间不应该有间隔dense_rank()?

select score,dense_rank() over(order by score desc) as rank from scores

180.连续出现的数字一个表logs(id,num),编写一个SQL查询,查找所有至少连续出现三次的数字

?官方答案

select 
    distinct a.num consecutivenums 
from
    logs a,logs b,logs c
where
    a.id = b.id+1 and b.id = c.id+1 
and 
    a.num=b.num and b.num=c.num

?使用开窗函数

select 
    distinct num ConsecutiveNums
from
    (select 
        num,n 
     from
        (select Num,id - row_number() over(partition by Num order by id) n from logs) 
     group by 
        num,n
     having 
        count(*) >= 3
     );

184.部门工资最高的员工一个员工信息表Employee(id,name,salary,dqpartmentid),一个部门信息表Department(id,name)

编写一个 SQL 查询(有Department,Employee,salary三个字段),找出每个部门工资最高的员工

力扣官方给出双字段子查询的方法

select 
    b.name as department
    ,a.name as employee
    ,a.salary as salary 
from 
    employee a left join department b on a.departmentid = b.id
where
    (a.departmentid,a.salary) 
in 
    (select departmentid,max(salary) from employee group by departmentid)

626.换座位一张seat座位表(id,student),改变相邻俩学生的座位,如果学生人数是奇数,则不需要改变最后一个同学的座位

select id
    ,decode(
            mod(id,2),
            1,
            lead(student,1,student) over(order by id),
            lag(student,1) over(order by id)
            ) as student 
from seat

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-15 15:56:05  更:2021-11-15 15:56:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 0:39:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码