【SQL学习进阶】从入门到高级应用【企业真题】

在这里插入图片描述

文章目录

  • 第一题
  • 第二题
  • 第三题
  • 第四题
  • 第五题
  • 第六题
  • 第七题
  • 第八题
  • 第九题
    • MySQL行转列
      • 使用case when+group by完成
  • 第十题

🌈你好呀!我是 山顶风景独好
💕欢迎来到我的博客,很高兴能够在这里和您见面!
💕希望您在这里可以感受到一份轻松愉快的氛围!
💕这里不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
🚀 欢迎一起踏上探险之旅,挖掘无限可能,共同成长!

🏠大家订阅本专栏!本专栏旨在为SQL初学者提供一条逐步迈向高级应用的学习之路,带您从零开始,一步一步练习,逐步掌握SQL的精髓,实现技能的提升与飞跃!😊

第一题

1.jpg

# 第一步:找小于等于80分的学员姓名
select distinct name from t_student where fenshu <= 80# 第二步:not in
select distinct name from t_student where name not in(select distinct name from t_student where fenshu <= 80)

第二题

2.jpg
image.png
其中,两个表的关联字段为申请单号。
1)查询身份证号为440401430103082的申请日期。
2)查询同一个身份证号码有两条以上记录的身份证号码及记录个数。
3)将身份证号码为440401430103082的记录在两个表中的申请状态均改为07。
4)删除g_cardapplydetail表中所有姓李的记录。
模拟数据:考试做这种题目最重要的是要冷静下来,只有静下来SQL才能写好。要模拟数据。看到数据SQL就好写了。
image.png
1)查询身份证号为440401430103082的申请日期。
bigint转date,可以使用from_unixtime函数。

select a.g_applydate from g_cardapply a join g_cardapplydetail b on a.g_applyno = b.g_applyno where b.g_idcard = '440401430103082'

2)查询同一个身份证号码有两条以上记录的身份证号码及记录个数。

select count(g_idcard),g_idcard from g_cardapplydetail group by g_idcard having count(g_idcard) >= 2

3)将身份证号码为440401430103082的记录在两个表中的申请状态均改为07。

UPDATE g_cardapply
JOIN g_cardapplydetail 
ON g_cardapply.g_applyno = g_cardapplydetail.g_applyno 
ANDg_cardapplydetail.g_idcard = '440401430103082'
SET g_cardapply.g_state = '07',
g_cardapplydetail.g_state = '07'

4)删除g_cardapplydetail表中所有姓李的记录。

delete t1,t2 from g_cardapply t1 join g_cardapplydetail t2 on t1.g_applyno=t2.g_applyno where t2.g_name like '李%';

第三题

面试题3.jpg
面试题5.jpg
表名:stuscore
1)统计如下:课程不及格[059]的多少个,良[6080]多少个,优[81-100]多少个。
2)计算科科及格的人的平均成绩。

第四题

QQ图片20151126234632.jpg
1)请用一条SQL语句查询出不同部门中担任“钳工”的职工平均工资。
2)请用一条SQL语句查询出不同部门中担任“钳工”的职工平均工资高于2000的部门。

第五题

image.png
Employee是雇员信息表:
雇员姓名(主键):person-name
街道:street
城市:city
Company是公司信息表:
公司名称(主键):company-name
城市:city
Works是雇员工作信息表:
雇员姓名(主键):person-name
公司名称:company-name
年薪:salary
Manages是雇员工作关系表:
雇员姓名(主键):person-name
经理姓名:manager-name
模拟数据:
员工表:employee
image.png
公司表:company
image.png
雇员工作信息表:Works
image.png
雇员工作关系表:Manages
image.png

请给出下面每一个查询的SQL语句:

  1. 找出所有居住地与工作的公司在同一城市的员工的姓名。
  2. 找出比Small Bank Corporation的所有员工收入都高的所有员工的姓名。
  3. 找出平均年薪在10000美元以上的公司及其平均年薪。

第六题

IMG_1621.JPGIMG_1616.JPG
客户表Client
image.png
订单表Order
image.png
客户订单表ClientOrder
image.png
图书表Book
image.png

  1. 请写出一条SQL语句,查询出每个客户的所有订单并按照地址排序,要求输出格式为:address client_name phone order_id
  2. 请写出一条SQL语句,查询出每个客户订购的图书总价。要求输出格式为:client_name total_price
  3. 如果要求每个订单可以包含多种图书,应该如何修改Order表的主键?为了保证每个订单只被一个客户拥有,应该在ClientOrder表上增加怎样的约束?

第七题

image.png
image.png
模拟数据:
学生表:student
image.png
课程表:course
image.png
成绩表:sc
image.png
教师表:teacher
image.png

  1. 查询1号课比2号课成绩高的所有学生学号。
  2. 查询平均成绩大于60分的学号和平均成绩。
  3. 查询所有学生学号、姓名、选课数、总成绩。
  4. 查询姓“李”的老师的个数。
  5. 查询没学过“叶平”老师课的学号、姓名。

第八题

image.png
学生表:student
image.png
课程表:class
image.png
选课表:chosen_class
image.png

  1. 没有选修课程编号为C1的学生姓名
  2. 列出每门课程名称和平均成绩,并按照成绩排序
  3. 选了2门课以上的学生姓名。

第九题

image.png
image.png
要转换成:
image.png

MySQL行转列

MySQL行转列又叫做数据透视。什么叫做行转列?将原本横向排列的数据透视成纵向排列的数据,进而进行计算、分析、展示等操作。

假设有一个学生选课成绩表,包含学生姓名(stu_name)、课程名称(course_name)和分数(score)三个字段。在原始数据中,每个学生在不同的课程中都有自己的得分情况,数据样例如下:

stu_namecourse_namescore
张三数学80
张三英语85
张三历史90
李四数学75
李四英语92
李四历史85
王五数学88
王五英语90
王五历史95

可以使用行转列操作,将每个学生在不同课程中的分数拆分成多条记录,每条记录包含一个课程以及对应的分数。转换后的数据样例如下:

stu_name数学英语历史
张三808590
李四759285
王五889095

从上表中可以看出,在行转列之后,每一行记录都表示了一个学生在不同课程中的分数。这样更便于对不同科目的分数进行比较、计算平均值等分析操作。

使用case when+group by完成

drop table if exists t_student;
create table t_student(stu_name varchar(10),course_name varchar(10),score int
);
insert into t_student(stu_name, course_name, score) values('张三', '数学', 80);
insert into t_student(stu_name, course_name, score) values('张三', '英语', 85);
insert into t_student(stu_name, course_name, score) values('张三', '历史', 90);
insert into t_student(stu_name, course_name, score) values('李四', '数学', 75);
insert into t_student(stu_name, course_name, score) values('李四', '英语', 92);
insert into t_student(stu_name, course_name, score) values('李四', '历史', 85);
insert into t_student(stu_name, course_name, score) values('王五', '数学', 88);
insert into t_student(stu_name, course_name, score) values('王五', '英语', 90);
insert into t_student(stu_name, course_name, score) values('王五', '历史', 95);
commit;
select * from t_student;

image.png
行转列后的效果是:
image.png
sql如下:

selectstu_name,max(case course_name when '数学' then score else 0 end) as '数学',max(case course_name when '英语' then score else 0 end) as '英语', max(case course_name when '历史' then score else 0 end) as '历史' 
from t_student
group by stu_name;

通过以上内容的学习,我们这个面试题就迎刃而解了:

selectyear,max(case season when '一季度' then count else 0 end) as '一季度',max(case season when '二季度' then count else 0 end) as '二季度',max(case season when '三季度' then count else 0 end) as '三季度',max(case season when '四季度' then count else 0 end) as '四季度'
from t_temp 
group by year;

第十题

image.png

select x.a 开始数字, y.a 结束数字
from (select m.a,row_number() over(order by m.a) as rownum from (select a, lag(a) over(order by a asc) as pre_a from t) m where m.a - m.pre_a != 1 or m.pre_a is null) x 
join (select n.a,row_number() over(order by n.a) as rownum from (select a, lead(a) over(order by a asc) as next_a from t) n where n.next_a - n.a != 1 or n.next_a is null) y 
on x.rownum = y.rownum;

解答上面这个题目需要具备以下知识点:

  • lag函数
  • lead函数
  • row_number函数

lag函数:获取当前行的上一行数据

select empno,ename,sal,(lag(sal) over(order by sal asc)) as pre_sal from emp;

image.png
注意:over函数用来指定“在…范围内”,通常和lag函数联用。

lead函数:获取当前行的下一行数据

select empno,ename,sal,(lead(sal) over(order by sal asc)) as next_sal from emp;

image.png
注意:over函数用来指定“在…范围内”,通常和lead函数联用。

row_number函数:可以为查询结果集生成行号:

select empno,ename,sal,row_number() over(order by sal) as rownum from emp;

image.png

利用row_number函数,将两个不相关的列拼接在一起显示:
image.png
image.png

select x.a, y.b 
from (select a,row_number() over(order by a) as rownum from t1) x 
join (select b,row_number() over(order by b) as rownum from t2) y 
on x.rownum = y.rownum;

image.png

CTE语法(公用表表达式):Common Table Expression。创建临时表的一种语法:

-- 查询每个部门平均工资的工资等级
-- 第一种写法
select t.deptno,t.avgsal,s.grade 
from (select deptno,avg(sal) as avgsal from emp group by deptno) t 
join salgrade s 
on t.avgsal between s.losal and s.hisal;-- 第二种写法:使用CTE语法
with cte_exp as(select deptno,avg(sal) as avgsal from emp group by deptno)
select cte_exp.deptno,cte_exp.avgsal,s.grade
fromcte_exp
joinsalgrade s
oncte_exp.avgsal between s.losal and s.hisal;

partition by:将数据分区,和group by区别是:group by是分组,然后和分组函数一起用。partition by分区不需要和分组函数一起使用

select deptno, empno,ename,sal,(lag(sal) over(partition by deptno order by sal asc)) as pre_sal from emp;

image.png

MySQL 8.0及以上版本中支持如下常用的窗口函数:

  1. ROW_NUMBER():排名函数,返回当前结果集中每个行的行号;
  2. RANK():排名函数,计算分组结果中的排名,相同的行排名相同且没有空缺,下一个行排名跳过空缺;
  3. DENSE_RANK():排名函数,计算分组结果中的排名,相同的行排名相同,排名连续,没有空缺;
  4. NTILE():将分组结果等分为指定的组数,计算每组的大小;
  5. LAG():返回分组内前一行的值;
  6. LEAD():返回分组内后一行的值;
  7. FIRST_VALUE():返回分组内第一个值;
  8. LAST_VALUE():返回分组内最后一个值;
  9. AVG()、SUM()、COUNT()、MIN()、MAX():聚合函数,可以配合OVER()进行窗口操作。

需要注意的是,MySQL的窗口函数和其他DBMS中的窗口函数相比较,可能略有不同,需要根据MySQL的文档进行使用。


✨ 这就是今天要分享给大家的全部内容了,我们下期再见!😊

🏠 我在CSDN等你哦!我的主页😍

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

疫情物资捐赠和分配系统的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;管理员管理&#xff0c;机构管理&#xff0c;用户管理&#xff0c;发放管理&#xff0c;物资管理 前台账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;物资论坛&#xff0c;公告信息…

STM32作业设计

目录 STM32作业设计 STM32作业实现(一)串口通信 STM32作业实现(二)串口控制led STM32作业实现(三)串口控制有源蜂鸣器 STM32作业实现(四)光敏传感器 STM32作业实现(五)温湿度传感器dht11 STM32作业实现(六)闪存保存数据 STM32作业实现(七)OLED显示数据 STM32作业实现(八)触摸按…

彻底卸载Windows Defender

概述 卸载Windows Defender的方法有很多&#xff0c;如修改注册表、组策略&#xff0c;执行脚本等等&#xff0c;这些方法操作过于繁琐和复杂&#xff0c;不适合小白&#xff0c;今天带来一款强大的卸载工具&#xff0c;只需要以管理员身份运行该软件即可&#xff0c;不用其他操…

禹晶、肖创柏、廖庆敏《数字图像处理(面向新工科的电工电子信息基础课程系列教材)》Chapter 6插图

禹晶、肖创柏、廖庆敏《数字图像处理&#xff08;面向新工科的电工电子信息基础课程系列教材&#xff09;》 Chapter 6插图

Stable Diffusion详细教程

目录 &#x1f40b;引言 &#x1f40b;Stable Diffusion基本概念 &#x1f988;潜在扩散模型 &#x1f988;图像生成原理 &#x1f40b;Stable Diffusion安装部署 &#x1f988;环境要求 &#x1f988;安装步骤 &#x1f40b;Stable Diffusion阶段 &#x1f988;准备阶…

git 下载失败

-- 错误0 加 sudo -- 错误 $ git clone https://github.com/espressif/arduino-esp32.git -b release/v2.x arduino Cloning into arduino... remote: Enumerating objects: 53886, done. remote: Counting objects: 100% (1194/1194), done. remote: Compressing objects: 1…

PHP 页面报错Warning</b>: Cannot modify header information - headers already sent by

先给出解决方案再解释&#xff0c;如果急着用就不用看解释了。 解决方案一&#xff1a;保存php文件编码为utf-8无BOM码&#xff0c;具体操作可以用notepad等编辑器完成&#xff0c;把 sesstion_start() 放在文档所有输出&#xff08;包括html标签和php的输出语句&#xff0c;具…

ch4网络层---计算机网络期末复习(持续更新中)

网络层概述 将分组从发送方主机传送到接收方主机 发送方将运输层数据段封装成分组 接收方将分组解封装后将数据段递交给运输层网络层协议存在于每台主机和路由器上 路由器检查所有经过它的IP分组的分组头 注意路由器只有3层(网络层、链路层、物理层) 网络层提供的服务 一…

Java筑基-集合[Set、Map、List、Stack、Queue]

这里写目录标题 一、Collection接口结构图二、Set集合1、常用方法 三、List集合1、List集合常用方法2、代码案例 四、Stack集合1、方法2、代码展示 五、Queue集合1、常用的方法2、代码展示 六、Map集合1、基本概念2、常用方法3、代码展示 一、Collection接口结构图 二、Set集合…

小熊家务帮day8-day9 客户管理模块2 (用户定位,地址簿,实名认证,银行卡信息上传等功能)

客户管理模块 0.用户定位功能0.1 需求0.2 接口分析0.3 接口开发Controller层开发Service层开发 1.我的地址簿功能1.1 需求1.2 数据库设计1.3 新增地址簿1.3.1 接口设计1.3.2 接口开发Controller层开发Service层开发测试功能 1.4 地址簿查询1.4.1 接口设计1.4.2 接口开发Control…

Caliburn.Micro框架学习笔记——多页面处理案例

在聊这个之前&#xff0c;我们先来看一个静态类 在 Caliburn.Micro 中&#xff0c;ViewLocator 是一个用于查找和关联视图与视图模型的静态类。默认情况下&#xff0c;它根据约定&#xff08;命名约定或其他规则&#xff09;自动找到与视图模型相对应的视图。然而&#xff0c;…

C语言 | Leetcode C语言题解之第126题单词接龙II

题目&#xff1a; 题解&#xff1a; char** list; int** back; int* backSize;// DFS uses backtrack information to construct results void dfs(char*** res, int* rSize, int** rCSizes, int* ans, int last, int retlevel) {int i ans[last];if (i 0) {res[*rSize] (c…

langchain构建一个 Agent 的过程

构建一个 Agent 的过程 概述 在使用大型语言模型&#xff08;LLM&#xff09;时&#xff0c;语言模型本身无法直接采取行动&#xff0c;只能输出文本。LangChain 的一个重要用例是创建代理&#xff08;Agents&#xff09;。代理是使用 LLM 作为推理引擎的系统&#xff0c;用于…

运用selenium爬取京东商品数据储存到MySQL数据库中

使用Selenium爬取京东商品数据并存储到MySQL数据库中的过程可以分为几个步骤&#xff1a; 1. 准备工作 安装所需库 确保你已经安装了Python环境以及以下库&#xff1a; selenium&#xff1a;用于自动化浏览器操作。pymysql 或 mysql-connector-python&#xff1a;用于连接M…

在MongoDB中,您可以通过以下步骤来创建账号密码,并限制其在特定数据库上的访问权限

在MongoDB中&#xff0c;您可以通过以下步骤来创建账号密码&#xff0c;并限制其在特定数据库上的访问权限&#xff1a; 连接到MongoDB数据库&#xff1a; 使用MongoDB的客户端&#xff08;如mongo shell或者MongoDB Compass&#xff09;连接到MongoDB服务器。 切换到admin数…

【TensorFlow深度学习】池化层的功能与类型详解

池化层的功能与类型详解 池化层的功能与类型&#xff1a;深度学习中的维度缩减与特征抽取艺术概述主要的池化类型结语 池化层的功能与类型&#xff1a;深度学习中的维度缩减与特征抽取艺术 在深度神经网络架构中&#xff0c;池化层&#xff08;Pooling Layer&#xff09;是一个…

实验报告 GUI窗体和标签

实验目的&#xff1a; 理解AWT和Swing工具包 掌握窗体和组件的创建方法。 实验要求&#xff1a; &#xff08;1&#xff09;掌握创建GUI窗体的操作 &#xff08;2&#xff09;掌握标签的使用 &#xff08;3&#xff09;代码应遵循Java编程规范&#xff0c;包含恰当的注释…

Kotlin 嵌套类和内部类

文章目录 嵌套类内部类 嵌套类 在类的内部可以定义其他的类&#xff0c;这是类结构上的嵌套&#xff08;Nested&#xff09;。 class Container {val name "Container"class NestedClass {fun getter() {// 此时无法访问外部类的成员// name}} }Note&#xff1a;接…

源码分析の前言

源码分析路线图&#xff1a; 初级部分&#xff1a;ArrayList->LinkedList->Vector->HashMap(红黑树数据结构&#xff0c;如何翻转&#xff0c;变色&#xff0c;手写红黑树)->ConcurrentHashMap 中级部分&#xff1a;Spring->Spring MVC->Spring Boot->M…

用Python装饰器打造强大的日志系统

用Python装饰器打造强大的日志系统 日志记录是软件开发中不可或缺的一部分&#xff0c;它帮助开发者追踪程序的执行过程、调试错误和分析性能。Python提供了多种日志记录工具&#xff0c;但如何将日志记录功能优雅地集成到代码中&#xff0c;是一个值得探讨的问题。本文将介绍如…