SQL奇难怪状知识点分享

news2025/1/27 12:42:33

SQL执行顺序

select 语句的完整结构:

select 
  去重 要查询的字段
from
  表(注意:表和字段可以取别名)
xxxx(left/right/fulljoin 要连接的表  on 等值判断(顺序:先onwherewhere
  (具体的值/子查询,不包含聚合函数的过滤条件)
group by
  (通过哪个字段来分组)
having
  (过滤分组后的信息,条件和where一样,位置不同,包含聚合函数的过滤条件)
order by
  通过哪个字段排序
limit
  (分页)

SQL语句的执行顺序:
from -> on -> join -> where -> group by -> having -> select -> distinct -> order by -> limit
image.png
可以尝试记一下sql的执行顺序,对自己写sql以及sql调优有帮助,理解记忆也不是很难。
sql查询最重要的当然是从哪张表中查询,第一个就是from,和join后的表,当然在这之前可以确定一下,关联的字段那就是on,接下来是过滤的条件,就是where,后面紧接着就是当然就是group by和having了,然后就是返回查询结果,select选择返回指定的列,当然是distinct去重后的列,然后便是按照要求返回的数据是不是要排序啊order,返回指定的个数limit。你看,理解记忆一下,是不是还挺简单的。

group by分组题 行转列

create table tableA (Name varchar(10),Course varchar(10) ,Reslut  int) ;  
insert into tableA(Name , Course, Reslut) values('N1' , '语文' , 74) ;
insert into tableA(Name , Course , Reslut) values('N1' , '数学' , 83) ;
insert into tableA(Name , Course , Reslut) values('N1' , '物理' , 93) ;
insert into tableA(Name , Course , Reslut) values('N2' , '语文' , 74) ;
insert into tableA(Name , Course , Reslut) values('N2' , '数学' , 84) ;
insert into tableA(Name , Course , Reslut) values('N2' , '物理' , 94);

image.png
我的记录:
建表之后,表的结构为:
image.png

SELECT
	Name,
	sum(if(course = '语文',reslut,0)) '语文',
	sum(if(course = '数学',reslut,0)) '数学',
	sum(if(course = '物理',reslut,0)) '物理'
FROM
	tablea
GROUP BY name;

这个题就是要注意sum和if函数的使用,其他没有什么难点,好像这道题是面试的重点题哦,好好记住它🥰
肯定是要用到group by函数,但是我group by函数不太熟悉,故记录一下此函数的学习记录。

聚合函数

SQL聚合函数是计算一组数据的集合并返回单个值。
除count以外,聚合函数忽略空值,如果count函数的应用对象是一个确定列名,并在该列存在空值,此时count仍会忽略空值
因为聚合函数对一组值进行操作,所以它通常与select语句的group by子句一起使用,以计算每个分组提供信息的度量。

group by分组

分组是使用数据库时必须处理的最重要的任务之一。要将行分组,使用group by子句。
group by子句式select语句的可选子句,它根据指定列的匹配将行组合成组,每组返回一行。

在select子句中包含聚合函数不是强制的。但是,如果使用聚合函数,它将计算每个组的汇总值。
需要强调是的,在对行进行分组之前应用where子句,而在对行进行分组之后应用having子句。也就是说,where子句应用于行,而having子句应用于分组。
要对组进行排序,请在group by子句后添加order by子句。
group by子句中出现的列称为分组列,如果分组列包含null值,则所有null值都汇总到一个分组中,因为group by子句认为null值相等
常见的聚合函数:sum、max、min、avg、count。
group by后面可以接多个列,表示按后面所有列相等分组。
在分组聚合的场景下,哪些字段可以出现在select子句中?

  • 1.常量
  • 2.聚合函数内的字段
  • 3.参与分组的字段

group_concat函数

将group by产生的同一个分组中的值连接起来,返回一个字符串结构。
group_concat函数首先根据group by指定的列进行分组,将同一组的列显示出来,并用分隔符分割。
group_concat函数的语法

group_concat(distinct 字段名 order by 排序字段 asc/desc separator '分隔符')

使用distinct可以排除重复值;
separator是一个字符串值,默认为逗号;

列转行

SELECT 
		lateral view explode()
from tablea

lateral view explode()是Hive SQL中的语法,属于UDF函数,explode()函数也被称为“炸裂函数”,顾名思义,就是将一列数据“炸裂”为多行数据,即有列转行的效果。
lateral view关键字用于扩展查询结构,使得能够在查询中使用函数或操作符处理数组或嵌套数据结构。
explode函数用于将数组或嵌套结构的数据展开成多行数据,每个元素或字段值对应一行。会在explode()函数中指定需要拆分的列名。
这段SQL语法的作用是将某列数据拆分成多行,方便后续的数据处理和分析。

连接ip人数最多

image.png

SELECT
	ip,count(ip) 'ip连接人数最多'
from ip
GROUP BY ip
ORDER BY COUNT(ip) DEsqlUserSC
LIMIT 1

limit和offset用法

limit

limit 开始值,结束值
select * from stu limit m,n;
m:开始值 从第m+1行开始;
n:结束值 供展示n条数据

不能在limit中使用变量,例题《第N高的薪水》
在SQL中,limit子句用于限制查询结构的行数。然后它不允许直接使用变量作为行数的参数。
这是因为在查询计划生成的时候,数据库需要确定查询的结果集大小,以便进行优化和执行。因此,limit子句只能接受常量值,不能接受变量。

CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
BEGIN
declare m int;
set m = N-1;
  RETURN (
       select
                (
                    select 
                        distinct salary
                    from
                        Employee
                    order by salary desc
                    limit m,1
                )
        as getNthHighestSalary
);
END

offset

offset n 去掉几个值
就是跳过n个数据,取第n+1值

conclusion

数据中的数据,计算是从0开始的。

第N高的薪水

image.png
image.png

CREATE FUNCTION getNthHighestSalary(N INT) RETURNS INT
BEGIN
    declare m int;
    set m = N - 1;
RETURN (
    select
        distinct salary
    from 
        Employee
    order by salary desc
    limit m,1
);
END

limit函数不能直接用变量,故需要自己定义常量接收,定义函数为:
declare m int;
set m = N;
先用declare关键字定义,再用set设置。
这个题目对我来说本身其实不难,难的其实是我对sql创建函数的陌生,多看看这道题,多写写牢记它🤣

group by+having 或group by + 临时表

image.png
group by + 临时表

select email
from (
  select email,count(email) as num
  from person
  group by email  
)as sta
where num>1;

很简单哇,临时表,就是括号as 表名,select查询出来时一张表,在这张表直接查询就行。
group by+having

select
  Email
FROM
  person
group by Email
having count(Email)>1;

having是用于group by之后对数据进行筛选。

删除重复邮件

image.png
先根据email分组,筛选出每个邮件的最小id;
由于需要的是具体id值来参与条件筛选,所以要筛选出具体id;
有了筛选条件就可以进行删除了。

delete 
from Person 
where Person.id not in (
    select e.i from (
        select min(id) as i from Person group by email
    ) as e
);

这道题最关键就是使用group by分组,然后用聚合函数min去找到最小的id。
测试的时候,我觉得可以使用如下代码,但是在报错了代码:1093 - you can’t specify target table

delete from person
where person.id not in
(
	select min(id) as id from Person group by email
)

image.png
原来是不能同时既在一张表select,又去update到这张表。所以需要增加一张临时表过渡一下。

上升的温度

image.png

select w1.id Id
from Weather w1
join Weather w2
on datediff(w1.recordDate ,w2.recordDate ) = 1
where w1.Temperature > w2.Temperature 

datediff函数用于返回两个日期之间的边界数差异。这个函数可以计算两个日期之间的年、月、日、小时、分钟、秒或周数差异。
datediff(datepart,startdate,enddate)
datepart是指定要返回日期部分的参数,比如year、month、day、hour、minute、second、week等
startdate和enddate是要进行差异计算的日期,开始日期和结束日期。

IF表达式 和 case when条件表达式

IF(判断条件,结果1,结果2)
判断条件为true,则返回结果1;否则返回结果2。
if一般适合用于判断两值分类。
case when:

case 
when 列名 = ‘A’ then ‘A1',
when 列名 = ‘B’ then ‘B1’,
when 列名 = ‘C’ then  ‘C1'
else 'D1
end

then后面的值与else后面的值类型应一致
也可以把列名全部提前到case后面。
case when 一般适用于两值即两值以上分类。
if和case可以作为最后生成的列返回。

事务

-- 开始事务
START TRANSACTION;

-- 执行一些SQL语句
UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;

-- 判断是否要提交还是回滚
IF (条件) THEN
    COMMIT; -- 提交事务
ELSE
    ROLLBACK; -- 回滚事务
END IF;

1.开启事务:使用begin或者start transaction命令来开始一个事务。
2:执行SQL语句:
3.判断是否提交或回滚:
根据业务逻辑判断是否要提交或回滚事务。
使用IF条件来判断,如果满足条件则执行commit提交事务,否则执行rollback回滚事务。
4.结束事务:
使用commit命令来提交事务,将所有的修改永久保存到数据库;
使用rollback命令来回滚事务,撤销自上次提交以来所做的所有更改。因为事务是多条sql语句同时执行,要是在事务运行过程中发现了某种故障,事务不能继续执行,系统将事务中对数据库所有已完成的操作全部撤销,滚回到书屋开始时的状态。

窗口函数

它对查询结果的一个窗口(也称为分区)执行计算并返回结果。
窗口函数,也叫OLAP函数(联机分析处理),可以对数据库数据进行实时分析处理,它的基本语法如下:
<窗口函数> over (partition by <用于分组的列名> order by <用于排序的列名>)
窗口函数.png
lag():查询当前行向上偏移n行对应的结果(过去)
lead():查询当前行向下偏移n行对应的结果(未来)
窗口函数原则上只能写在**select**子句中。
窗口函数的名称来源于:over子句中的partition by分组,这里的窗口表示数据的范围。总之,窗口函数具备分组和排序功能,不减少原表的行数。
窗口函数简单理解就是rank()、dense_rank()用来获取排名,可以用partition by分组order by对某一字段的数据进行排名
当然,也可以省略掉partition by语句,此时表示不进行分区,对目标表内所有的数据根据某列进行排序(不过此时,窗口函数就失去了其功能)。

join和union的区别

  • join(连接查询):是将两个查询(或表),以‘两两横同对接’的方式。

所得到的所有行,即表示表中的某行,跟另一个表中的某行。
进行‘横向对接’,得到一个新行。

  • union(联合查询):指将2个或2个以上的字段数量相同的查询结构,‘纵向堆叠’后合并为一个结果。

union操作符用于合并两个或多个select语句的结果集
union操作符只能连接字段与字段,而不能连接字段与表或者表与表,哪怕字段以及字段名称、格式都一样也不行。因为union操作符前后是不能带有括号的,因为带有括号的话,sql就容易判定这是一个子查询表,连接会报错。
union all的效率更高,不用去判断是否存在重复值。

部门工资最高的员工

image.png

select  d.name Department,e.name Employee,salary Salary
from Employee e
join Department d
on e.departmentId = d.id
where (d.id,salary) in (
    select departmentId,max(salary)
    from Employee 
    group by departmentId
)

聚合函数中的maxmin只会返回1行,不会将所有的最大值都返回回来。
这道官方题解给出的是,直接找到每个部门最大薪资作为子查询,然后再在总表中找到某个部门与该薪资对应的人,就可以返回所有最高薪资的员工。

select  Department.name Department,r.name Employee,salary Salary
from (
    select 
    name,
    salary,
    departmentId,
    dense_rank() over (partition by departmentId order by salary desc) 'rank'
from Employee e
)r
join Department
on r.departmentId = Department.id and r.rank=1

也可以用dense_rank()窗口函数实现,最高薪资,就是薪水排名第一,只要将所有薪水排名第一的雇员输出即可。窗口函数是将每一行的数据划分一个窗口,然后对窗口范围内的数据进行计算,最后将计算结果返回给该行数据,这是一个新生成的字段,不能用于筛选,需要作为表返回后,对表进行筛选。

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

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

相关文章

win10安装.NET Framework 3.5(包括.net2.0和3.0)

打开控制面板 选择”程序” 点击”启用或关闭Windows功能“ 把.NET Framework 3.5选项勾选即可&#xff0c;若没有下载的&#xff0c;下载即可。 PS:如果下载过程出错&#xff0c;按如下流程&#xff1a; 右击”此电脑”选择“管理”&#xff0c;找到“服务和应用程序”&#x…

C++之初阶模板

个人主页&#xff1a;救赎小恶魔 欢迎大家来到小恶魔频道 好久不见&#xff0c;甚是想念 今天我们要深入讲述C内存管理 目录 引言&#xff1a; 模板 1. 泛型编程 2. 模板函数 2.1函数模板的原理 2.2模板函数的实例化 2.3函数模板的匹配 3.类模板 STL STL 的主要组…

2024副业指南:年轻人热捧的七大赚钱副业,在家就能做!做得好的月入过万了

副业&#xff0c;听起来就像是在主业之外的“小打小闹”&#xff0c;但你知道吗&#xff1f;很多人通过副业实现了财务自由&#xff0c;甚至有的人副业收入超过了主业&#xff01; 今天&#xff0c;就让我们一起探索那些适合你的副业机会&#xff0c;让你在工作之余也能成为收入…

SpringCloudAlibaba:4.3云原生网关higress的JWT 认证

概述 简介 JWT是一种用于双方之间传递安全信息的简洁的、URL安全的声明规范。 定义了一种简洁的&#xff0c;自包含的方法用于通信双方之间以Json对象的形式安全的传递信息&#xff0c;特别适用于分布式站点的单点登录&#xff08;SSO&#xff09;场景 session认证的缺点 1.安…

内网安全【2】——域防火墙/入站出站规则/不出网隧道上线/组策略对象同步

-隧道技术&#xff1a;解决不出网协议上线的问题(利用出网协议进行封装出网)&#xff08;网络里面有网络防护&#xff0c;防火墙设置让你不能正常访问网络 但有些又能正常访问&#xff0c;利用不同的协议tcp udp 以及连接的方向&#xff1a;正向、反向&#xff09; -代理技术&…

WPF TextBox文本框 输入提示

思路 Grid标签里面创建Label和TextBox&#xff0c;这是一个整体。 TextBox 为空显示 Label OR TextBox 不为空隐藏 Label 。 注意 两个标签的前后顺序。 TextBox文本的背景颜色设置为透明&#xff0c;不然会无法看到 Label 内容。 ElementNametxtStoreName&#xff1a;指定…

【JavaWeb】网上蛋糕项目商城-注册,登录,修改用户信息,提交订单

概念 通过以上多篇文章的讲解&#xff0c;对该项目的功能已经实现了很多&#xff0c;本文将对该项目的用户注册&#xff0c;登录&#xff0c;修改用户信息&#xff0c;以及用户添加至购物车的商品进行提交订单等功能的实现。 注册功能实现 点击head.jsp头部页面的注册按钮&a…

【触摸案例-手势解锁案例-连线到按钮 Objective-C语言】

一、接下来,我们接着来说这个,连线的问题啊, 1.连线的问题啊,也就是说,我现在点击一个按钮, 在移动到下一个按钮的时候,在两个按钮中间,在两个按钮都亮起来的时候呢,我们肯定是让它去画一条线的,那么, 1)首先,如果我现在从第一个按钮,连到第二个按钮,那么,这条…

WSL2中使用USB串口实验

一、主要参考网站: Connect USB devices | Microsoft Learn 连接 USB 设备 | Microsoft Learn 二、安装usbipd-win WSL 本身并不支持连接 USB 设备,因此你需要安装开源 usbipd-win 项目 PS C:\Users\issta> winget install --interactive --exact dorssel.usbipd-win …

【网络编程】HTTPS协议详解

引言 HTTPS是HTTP协议的安全版本&#xff0c;通过使用SSL&#xff08;安全套接层&#xff09;或TLS&#xff08;传输层安全&#xff09;协议加密通信&#xff0c;为数据传输提供了保密性、完整性和身份认证。与传统的HTTP相比&#xff0c;HTTPS能够防止敏感信息被窃取、篡改和…

微信公众号有哪些类型,微信服务号和订阅号有哪些区别

什么是微信公众号&#xff1f; 微信公众号是国内社交媒体平台微信上的公众账号。它们是允许公司发布内容&#xff0c;收集追随者并推广其产品或服务的商业帐户。微信公众号主要有两种类型&#xff1a;订阅账号和服务账号。 微信月活跃用户突破12亿 微信最近达到了平台上的月活…

嵌入式的发展怎么样?

据统计&#xff0c;目前嵌入式人才处于供不应求的状态&#xff0c;对嵌入式工程师的需求达到了全部需求量的 60%至 80%&#xff0c;而且每年还以 20%的速率在增长。因此&#xff0c;学习嵌入式对于大多数人来说&#xff0c;是比较容易找到工作的。 让我再为大家举个例子。近年来…

Pandas进阶

文章目录 第1关&#xff1a;Pandas 分组聚合第2关&#xff1a;Pandas 创建透视表和交叉表 第1关&#xff1a;Pandas 分组聚合 编程要求 使用 Pandas 中的 read_csv() 函数读取 step1/drinks.csv 中的数据&#xff0c;数据的列名如下表所示&#xff0c;请根据 continent 分组并…

ai智能答题助手,这四款软件让知识触手可及!

在数字化时代&#xff0c;知识的获取变得前所未有的便捷。随着人工智能技术的不断发展&#xff0c;AI智能答题助手应运而生&#xff0c;成为了人们学习、工作和生活中的得力助手。今天&#xff0c;就为大家介绍四款备受欢迎的AI智能答题助手软件&#xff0c;让你感受知识的魅力…

Python 进阶(十九):解析命令行参数(argparse 模块)

大家好&#xff0c;我是水滴~~ 当处理命令行参数时&#xff0c;Python 的 argparse 模块是一个强大而灵活的工具。它提供了一个简单且一致的方式来定义命令行参数、选项和子命令&#xff0c;并帮助你解析和验证用户提供的输入。本教程将详细介绍 argparse 模块的使用方法和常见…

5.1 Java全栈开发前端+后端(全栈工程师进阶之路)-服务端框架-MyBatis框架-相信我看这一篇足够

0.软件框架技术简介 软件框架&#xff08;software framework&#xff09;&#xff0c;通常指的是为了实现某个业界标准或完成特定基本任务的软件组件规范&#xff0c;也 指为了实现某个软件组件规范时&#xff0c;提供规范所要求之基础功能的软件产品。 框架的功能类似于基础设…

环形链表问题详解

引言 环形链表的题大家都应该做过&#xff0c;如果没有做过可以去某扣上做一下 ,下面有传送门 141. 环形链表 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/linked-list-cycle/submissions/530160081/ 正文 如果在面试的情况下出现了环形链表的题大…

阿里云VOD视频点播流程(1)

一、开通阿里云VOD 视频点播&#xff08;ApsaraVideo VoD&#xff0c;简称VOD&#xff09;是集视频采集、编辑、上传、媒体资源管理、自动化转码处理、视频审核分析、分发加速于一体的一站式音视频点播解决方案。登录阿里云&#xff0c;在产品找到视频点播VOD &#xff0c;点击…

QT4-升级到QT5(1)

1.C报错汇总_nafxcwd.lib error lnk2001-CSDN博客1 1.QT3Support QWidget::setShown 改为QWidget::setVisible 2.头文件 #include<QWidget> 3.部分函数替换

Neo4j+LLM+RAG 环境配置报错处理

开发KGLLMRAG程序时遇到以下报错&#xff0c;记录下处理方案&#xff1a; ValueError: Could not use APOC procedures. Please ensure the APOC plugin is installed in Neo4j and that ‘apoc.meta.data()’ is allowed in Neo4j configuration 这个参考文章&#xff1a;link…