牛客题霸-SQL篇(刷题记录二)

本文基于前段时间学习总结的 MySQL 相关的查询语法,在牛客网找了相应的 MySQL 题目进行练习,以便加强对于 MySQL 查询语法的理解和应用。

由于涉及到的数据库表较多,因此本文不再展示,只提供 MySQL 代码与示例输出。

以下内容是牛客题霸-SQL 篇的第 223 - 262 道题目的 MySQL 代码答案,本文跳过了其中一些更新、删除、修改等操作的题目。


SQL 223:查询没有分类的电影 id 及电影名称

select f.film_id, f.title
from film f
left join film_category fc
on f.film_id = fc.film_id
where fc.category_id is null

在这里插入图片描述

SQL 224:查询属于 Action 分类的所有电影名称和对应的电影描述信息

select title, description
from film f
join film_category fc
on f.film_id = fc.film_id
join category c
on fc.category_id = c.category_id
where c.name = 'Action'

在这里插入图片描述

SQL 226:将所有员工的 last_name 和 first_name 拼接起来作为 Name

select concat(last_name,' ',first_name) as Name
from employees

SQL 227-228:创建一个 actor 表并批量插入数据

create table if not exists actor(
   actor_id smallint(5) not null primary key,
   first_name varchar(45) not null,
   last_name varchar(45) not null,
   last_update timestamp not null
)

insert into actor(actor_id, first_name, last_name, last_update)
values
(1, 'PENELOPE', 'GUINESS', '2006-02-15 12:34:33'),
(2, 'NICK', 'WAHLBERG', '2006-02-15 12:34:33')

SQL 244:将所有员工的 last_name 和 first_name 通过 (') 连接起来

select concat(last_name, "'", first_name)
from employees

SQL 246:查询所有员工的 first_name,并按照 first_name 最后两个字母升序排列

select first_name
from employees
order by right(first_name, 2) 或者 order by substr(first_name, -2)

在这里插入图片描述

SQL 247:按照 dept_no 进行汇总,将属于同一个部门的 emp_no 按照逗号进行连接

select dept_no,
group_concat(emp_no separator ',') 
from dept_emp 
group by dept_no

在这里插入图片描述

SQL 248:查询排除在职(to_date = ‘9999-01-01’ )员工的最大、最小 salary 之后,其他的在职员工的平均工资 avg_salary

# 方法一
select (sum(salary) - max(salary) - min(salary))/(count(salary) - 2) as avg_salary
from salaries
where to_date = '9999-01-01'

# 方法二
select avg(salary) as avg_salary
from salaries
where salary>(
	select min(salary) from salaries
) and salary<(
	select max(salary) from salaries
) and to_date='9999-01-01'

在这里插入图片描述

SQL 253:查询 emp_no,first_name,last_name,奖金类型 btype,对应的薪水 salary 以及奖金金额 bonus,bonus 结果保留一位小数,按 emp_no 升序排序

select e.emp_no, first_name, last_name, btype, salary,
case
when btype = 1 then round(salary * 0.1, 1)
when btype = 2 then round(salary * 0.2, 1)
else round(salary * 0.3, 1)
end as bonus
from employees e
join emp_bonus eb 
on e.emp_no = eb.emp_no
join salaries s 
on e.emp_no = s.emp_no
where to_date = '9999-01-01'
order by e.emp_no

在这里插入图片描述

SQL 254:查询每个在职员工(to_date = ‘9999-01-01’)的累计 salary

select emp_no, salary,
sum(salary) over(order by emp_no) as running_total
from salaries
where to_date = '9999-01-01'

在这里插入图片描述

SQL 255:查询 employees 表中排名为奇数行的 first_name(输出结果不改变原表中 first_name 的顺序

select e.first_name
from employees e
join
(
	select first_name,
	rank() over(order by first_name) as rn
	from employees
) a
on a.first_name = e.first_name
where rn % 2 = 1

在这里插入图片描述

SQL 256:查询出现 3 次及 3 次以上的积分

select number from grade
group by number
having count(*) >= 3

在这里插入图片描述

SQL 257:查询通过题目个数的排名,通过题目个数相同的,排名相同,此时按照 id 升序排列

select *,
dense_rank() over(order by number desc) as t_rank
from passing_number

在这里插入图片描述

SQL 258:查询每个人的任务情况,没有任务的也要输出,并按照每个人的 id 升序排列

select p.id, name, content
from person p
left join task t
on p.id = t.person_id
order by p.id

在这里插入图片描述

SQL 259:查询每一个日期里面,正常用户发送给正常用户邮件失败的概率是多少,结果保留到小数点后 3 位,并按照日期升序排列

with a as(
    select id from user
    where is_blacklist = 0
) -- 正常用户的 id

select date,
round(avg(if(type = 'completed', 0, 1)), 3) as p
from email e
where e.send_id in(
	select id from a
)
and e.receive_id in(
 	select id from a
 )
group by date
order by date

SQL 260:查询每个用户最近一天登录的日子,并按照 user_id 升序排列

# 方法一
select user_id, max(date) as date
from login
group by user_id
order by user_id


# 方法二:窗口函数
with a as(
    select user_id, date,
    rank() over(partition by user_id order by date desc) as rn
    from login  
)

select user_id, date
from a
where rn = 1
order by user_id

SQL 261:查询每个用户最近一天登录的日子,用户的名字,及用户用的设备的名字,并按照 user_name 升序排列

# 方法一:rank() 的窗口函数
with a as(
    select u.name as u_n, c.name as c_n, l.date as date,
    row_number() over(partition by user_id order by l.date desc) as rn
    from login l
    join user u
    on l.user_id = u.id
    join client c
    on l.client_id = c.id
)

select a.u_n, a.c_n, a.date
from a
where rn = 1
order by a.u_n


# 方法二:max(date) 的窗口函数
with a as(
	select u.name as u_n, c.name as c_n, l.date as date,
	max(l.date) over(partition by user_id) as max_date
	from login l
	join user u
	on l.user_id = u.id
	join client c
	on l.client_id = c.id
)

select a.u_n, a.c_n, a.date
from a
where a.date = a.max_date
order by a.u_n

在这里插入图片描述

SQL 262:查询新登录用户次日成功的留存率,即第 1 天登陆之后,第 2 天再次登陆的概率,保留小数点后 3 位

# 方法一
with a as(
	select *,
    min(date) over(partition by user_id) as first_day
	from login
), -- 每个 user 首次登陆的日期
b as(
	select count(distinct user_id)
    from login
) -- 总的 user 数量

select round(count(distinct a.user_id)/(select * from b), 3) as p
from a
where datediff(date, first_day) = 1


# 方法二
select round(count(distinct a.id) / (select count(distinct user_id) from login ),3)
from
(select user_id id, date,
lead(date,1)over(partition by user_id order by date) date2
from login) a
where  datediff(date2,date)=1;

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/481107.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于ssm的音乐视频网站系统(可听音乐和看视频+数据库+报告+免费远程调试

项目介绍: 基于ssm的音乐视频网站系统&#xff08;可听音乐和看视频&#xff09;。Javaee项目&#xff0c;ssm项目。采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring SpringMvc Myba…

sd卡受损怎么恢复数据,sd卡受损了里面的数据怎么办

sd卡受损怎么恢复数据?听说你的SD卡出问题了?失去珍贵数据,简直就像是失去了一段珍贵的回忆,但别灰心,我们来解决这个问题!首先,我得说,SD卡受损是很常见的情况,可能是不小心摔了一下、插拔不当,或者是遇到了某种不可抗力的情况。sd卡受损了里面的数据怎么办?幸运的…

Linux--Flappy_bird实现

代码实现&#xff1a; #include<stdio.h> #include<curses.h> #include<signal.h> #include<sys/time.h> #include<stdlib.h>#define BIRD #define BLANK #define PIPE /**定义管道结构体**/ typedef struct Pipe {int x;//列int y;//横struc…

鸿蒙一次开发,多端部署(九)应用市场首页

本小节将以应用市场首页为例&#xff0c;介绍如何使用自适应布局能力和响应式布局能力适配不同尺寸窗口。 页面设计 一个典型的应用市场首页的UX设计如下所示。 观察应用市场首页的页面设计&#xff0c;不同断点下的页面设计有较多相似的地方。 据此&#xff0c;我们可以将页…

需求:JSON数据显示null值或者不显示null值

使用hutool的工具类 import cn.hutool.json.JSON; import cn.hutool.json.JSONConfig; import cn.hutool.json.JSONUtil;public class Main {public static void main(String[] args) {String sss "{\"1\":\"a\",\"2\":null}";// 不…

【算法】子集(LIS最长上升子序列)

文章目录 题目输入描述输出描述示例分析思路最长递增子序列dp解法&#xff08;2/10&#xff09;binarySearch 贪心&#xff08;AC&#xff09; 题目 小强现在有 n n n个物品&#xff0c;每个物品有两种属性 x i x^i xi和 y i y^i yi。他想要从中挑出尽可能多的物品满足以下条…

Bootloader/IAP零基础入门(1.0) —— 设计一个Bootloader引导进入APP的程序,不含中断向量偏移

前言 &#xff08;1&#xff09;如果有嵌入式企业需要招聘湖南区域日常实习生&#xff0c;任何区域的暑假Linux驱动/单片机/RTOS的实习岗位&#xff0c;可C站直接私聊&#xff0c;或者邮件&#xff1a;zhangyixu02gmail.com&#xff0c;此消息至2025年1月1日前均有效 &#xff…

重磅消息!《大模型面试宝典》(2024版) 正式发布!

2022 年11月底&#xff0c;OpenAI 正式推出 ChatGPT &#xff0c;不到两个月的时间&#xff0c;月活用户就突破1亿&#xff0c;成为史上增长最快的消费者应用。 目前国内已发布的大模型超过200个&#xff0c;大模型的出现彻底改变了我们的生活和学习方式。 现在只要你想从事 A…

优化选址问题 | 模拟退火算法求解物流选址问题含Matlab源码

目录 问题代码问题 模拟退火算法(Simulated Annealing, SA)是一种概率性的全局优化算法,用于求解大规模组合优化问题。在物流选址问题中,模拟退火算法可以用来寻找成本最低、效率最高的仓库或配送中心位置。下面是一个简化的模拟退火算法求解物流选址问题的描述,并附带有…

阿里云OSS分布式存储

目录 &#x1f9c2;1.OSS开通 &#x1f32d;2.头像上传整合OSS &#x1f68d;2.1.引入依赖 &#x1f68d;2.2添加配置 &#x1f68d;2.3创建配置类 &#x1f68d;2.4添加实现类 &#x1f68d;2.5controller调用接口 &#x1f68d;2.6postman测试 1.OSS开通 1.登…

力扣---最长有效括号---动态规划,栈

动态规划思路&#xff1a; 最长xxxx的问题&#xff0c;从动态规划的角度去考虑&#xff0c;我们会将 g[i] 定义为以 第 i 位 结尾的小问题。在本道题中&#xff0c;我们将 g[i] 定义为以第 i 位为结尾的最长有效括号子串的长度。从头去遍历每一位&#xff0c;我们会发现只有s[i…

我的创作纪念日——在CSDN的三年

我的创作纪念日——在CSDN的三年 个人简介机缘收获个人成就学习成就墙文章专栏 日常成就憧憬 个人简介 &#x1f3d8;️&#x1f3d8;️个人主页&#xff1a;以山河作礼。 &#x1f396;️&#x1f396;️:Python领域新星创作者&#xff0c;CSDN实力新星认证&#xff0c;CSDN内…

134. 加油站(力扣LeetCode)

文章目录 134. 加油站题目描述暴力枚举&#xff08;超时&#xff09;代码一代码二&#xff08;优化&#xff09; 贪心算法方法一方法二 134. 加油站 题目描述 在一条环路上有 n 个加油站&#xff0c;其中第 i 个加油站有汽油 gas[i] 升。 你有一辆油箱容量无限的的汽车&…

【机器学习入门 】支持向量机

系列文章目录 第1章 专家系统 第2章 决策树 第3章 神经元和感知机 识别手写数字——感知机 第4章 线性回归 第5章 逻辑斯蒂回归和分类 前言 支持向量机(Support Vector Machine) 于1995年发表&#xff0c;由于其优越的性能和广泛的适用性&#xff0c;成为机器学习的主流技术&…

【11】工程化

一、为什么需要模块化 当前端工程到达一定规模后,就会出现下面的问题: 全局变量污染 依赖混乱 上面的问题,共同导致了代码文件难以细分 模块化就是为了解决上面两个问题出现的 模块化出现后,我们就可以把臃肿的代码细分到各个小文件中,便于后期维护管理 前端模块化标准…

活用 C语言之union的精妙之用

一、union的基本定义 Union的中文叫法又被称为共用体、联合或者联合体。它的定义方式与结构体相同,但意义却与结构体完全不同。下面是union的定义格式: union 共用体名 {成员列表}共用体变量名;它与结构体的定义方式相同,但区别在于共用体中的成员的起始地址都是相同的,…

Android Studio Gradle设置查看全部task

如果你在 Android Studio 的 Gradle 窗口中看不到所有的任务&#xff0c;你可以尝试以下步骤来解决这个问题 android studio 版本&#xff1a; Android Studio Iguana | 2023.2.1 Build #AI-232.10227.8.2321.11479570, built on February 22, 2024 打开 Android Studio 的设置…

【CSP】2020-12-3 带配额的文件系统 100分完整代码 最长的大模拟 使用指针优化数据结构

2020-12-3 带配额的文件系统 最长的大模拟 使用指针优化数据结构 索引2020-12-3 带配额的文件系统 最长的大模拟 使用指针优化数据结构思路遇到的问题(学到的东西)40分stl代码acwing 15/15 csp官网40分代码100分完整代码 索引 历年CSP认证考试真题题解总汇持续更新 2020-12-3…

框架结构模态分析/动力时程分析Matlab有限元编程 【Matlab源码+PPT讲义】|梁单元|地震时程动画|结果后处理|地震弹性时程分析| 隐式动力学

专栏导读 作者简介&#xff1a;工学博士&#xff0c;高级工程师&#xff0c;专注于工业软件算法研究本文已收录于专栏&#xff1a;《有限元编程从入门到精通》本专栏旨在提供 1.以案例的形式讲解各类有限元问题的程序实现&#xff0c;并提供所有案例完整源码&#xff1b;2.单元…

Bytebase 2.14.1 - 分支 (Branching) 功能支持 Oracle

&#x1f680; 新功能 分支 (Branching) 功能支持 Oracle。为 SQL 编辑器添加了项目选择器。 新增 SQL 审核规范&#xff1a; 禁止混合 DDL、DML 语句。禁止对同一张表进行不同类型的 DML 变更 (UPDATE,INSERT,DELETE)。 &#x1f514; 重大变更 工作空间设置中的「数据访问…