【SQL】窗口函数的妙用

ops/2024/9/23 14:35:50/

目录

语法

需求

示例

分析

代码


语法

开窗函数() over (partition by 列名 order by列名) 

  • partition by: 需要分区的列
  • order by: 对分区内排序

连接函数concat(string1, string2, ..., stringN)

  • string1, string2, ..., stringN:是要连接的一个或多个字符串。

需求

Insurance 表:

+-------------+-------+
| Column Name | Type  |
+-------------+-------+
| pid         | int   |
| tiv_2015    | float |
| tiv_2016    | float |
| lat         | float |
| lon         | float |
+-------------+-------+
pid 是这张表的主键(具有唯一值的列)。
表中的每一行都包含一条保险信息,其中:
pid 是投保人的投保编号。
tiv_2015 是该投保人在 2015 年的总投保金额,tiv_2016 是该投保人在 2016 年的总投保金额。
lat 是投保人所在城市的纬度。题目数据确保 lat 不为空。
lon 是投保人所在城市的经度。题目数据确保 lon 不为空。

编写解决方案报告 2016 年 (tiv_2016) 所有满足下述条件的投保人的投保金额之和:

  • 他在 2015 年的投保额 (tiv_2015) 至少跟一个其他投保人在 2015 年的投保额相同。
  • 他所在的城市必须与其他投保人都不同(也就是说 (lat, lon) 不能跟其他任何一个投保人完全相同)。

tiv_2016 四舍五入的 两位小数 。
 

示例 1:

输入:
Insurance 表:
+-----+----------+----------+-----+-----+
| pid | tiv_2015 | tiv_2016 | lat | lon |
+-----+----------+----------+-----+-----+
| 1   | 10       | 5        | 10  | 10  |
| 2   | 20       | 20       | 20  | 20  |
| 3   | 10       | 30       | 20  | 20  |
| 4   | 10       | 40       | 40  | 40  |
+-----+----------+----------+-----+-----+
输出:
+----------+
| tiv_2016 |
+----------+
| 45.00    |
+----------+
解释:
表中的第一条记录和最后一条记录都满足两个条件。
tiv_2015 值为 10 与第三条和第四条记录相同,且其位置是唯一的。第二条记录不符合任何一个条件。其 tiv_2015 与其他投保人不同,并且位置与第三条记录相同,这也导致了第三条记录不符合题目要求。
因此,结果是第一条记录和最后一条记录的 tiv_2016 之和,即 45 。

分析

编写解决方案报告 2016 年 (tiv_2016) 所有满足下述条件的投保人的投保金额之和:

多条件,考虑子查询、窗口函数等

他在 2015 年的投保额 (tiv_2015) 至少跟一个其他投保人在 2015 年的投保额相同。

至少跟另一个投保人在2015年的投保额度相同,换个角度,就是2015年同一投保额多于一人

通过窗口函数按照tiv2015分别计数,要求计数大于1即可实现,count(*) over(partition by tiv_2015) b

他所在的城市必须与其他投保人都不同(也就是说 (lat, lon) 不能跟其他任何一个投保人完全相同)。

城市必须与其他投保人都不同,即经纬度坐标不一样,换个角度,就是按照经纬度坐标分组,组内计数为1

同理可以通过窗口函数按照经纬度分别计数实现,这里需要注意concat的用法

CONCAT函数用于将两个或多个字符串值连接成一个字符串。

count(*) over(partition by concat(lat,lon)) a

在使用CONCAT函数时,如果任何参数为NULL,则行为可能因数据库而异。在MySQL和SQL Server中,CONCAT函数会忽略NULL值,但在其他数据库系统中可能需要特别处理。
字符串连接时,可能需要考虑空格或其他分隔符,以确保连接后的字符串易于阅读和理解。
某些数据库系统(如SQL Server)还提供了CONCAT_WS(CONCAT With Separator)函数,允许你指定一个分隔符来连接字符串,这在处理包含NULL值的字符串时特别有用。

代码

select round(sum(tiv_2016),2) tiv_2016
from
(select *, count(*) over(partition by concat(lat,lon)) a, count(*) over(partition by tiv_2015) bfrom Insurance
) t
where a=1 and b>1

 


http://www.ppmy.cn/ops/106271.html

相关文章

HTML 基础

HTML(HyperText Markup Language)是构建网页的标准标记语言。HTML包括一系列标签tag。通过这些标签,可以将网络上的文档格式统一,使分散的Internet资源连接为一个逻辑整体。HTML文本是由HTML命令组成的描述性文本,HTML命令可以说明…

身份验证技术应用10大关键趋势

身份验证是现代企业网络安全的基石,确保只有经过授权的用户或实体才能访问敏感信息或系统。近年来,身份验证技术取得了显著进展,如无密码身份验证、多因素身份验证和社交验证登录等新兴技术不断涌现,正在重塑传统身份验证的方式和…

Python系统教程003

变量的数据类型 将输入信息存入变量name中然后输出。 如果想通过键盘输 入信息再存入变量 中应该怎么办? 一、内容 input函数变量的数据类型变量的运算 (一)、input函数 1、input函数1 函数:用来完成某一个特定功能的代码 …

Python自动化:Python操作Excel的多种方式Pandas+openpyxl+xlrd

在Python中,操作Excel数据通常可以通过几个流行的库来实现,比如pandas、openpyxl、xlrd等。 下面会分别介绍这三个流行库来实现对Excel的操作。 博客主页:长风清留扬-CSDN博客每天更新大数据相关方面的技术,分享自己的实战工作经验…

CUDA统一内存:简化GPU编程的内存管理

CUDA统一内存:简化GPU编程的内存管理 在现代GPU编程中,内存管理一直是开发者面临的一个重要挑战。特别是在使用NVIDIA CUDA进行高性能计算时,如何在CPU和GPU之间高效地传输数据、以及如何管理这些数据的生命周期,都是影响程序性能…

MySQL集群

一、Mysql 在服务器中的部署方法 1.1源码安装 下载依赖性 dnf install cmake gcc-c openssl-devel ncurses-devel.x86_64 libtirpc-devel-1.3.3-8.el9_4.x86_64.rpm rpcgen.x86_64 解压压缩包并安装 tar zxf mysql-boost-5.7.44.tar.gz cd /root/mysql-5.7.44 cmake \ -DCM…

备忘录模式 详解

备忘录模式 简介: 保存一个对象的某个状态,以便在适当的时候恢复对象, 允许在不破坏封装性的前提下,捕获和恢复对象的内部状态。 场景: 很多地方都用到了备忘录模式, 比如网络消息的序列化和反序列化, 数据的本地保存与加载等, 最简单的json的dump和loa…

西北工业大学oj题-兔子生崽

题目描述: 兔子生崽问题。假设一对小兔的成熟期是一个月,即一个月可长成成兔,每对成兔每个月可以生一对小兔,一对新生的小兔从第二个月起就开始生兔子,试问从一对兔子开始繁殖,一年以后可有多少对兔子&…