在SQL Server中合并重叠日期

article/2025/10/22 22:57:54

1.合并SQL中的时间重叠的记录方法:A

--创建临时表,里面有重叠的日期declare @t table (Name varchar(100),  starttime  datetime,  endtime datetime);
insert into @t values('A'   , '2017-01-02 00:00' , '2017-03-28 00:10'),('A'   , '2017-05-14 23:50' , '2017-05-29 23:50'),('B'   , '2017-05-18 00:00' , '2017-05-18 04:00'),('B'   , '2017-05-18 02:00' , '2017-05-18 03:00'),('C'   , '2017-01-02 00:00' , '2017-01-17 15:50'),('C'   , '2017-01-14 03:50' , '2017-01-28 15:50');
--定义临时表:开始日期:去掉开始日期在日期范围内的数据
with starttimes as 
( select distinct name, starttime from @t as t1 where not exists (select * from @t as t2 where t2.name = t1.name and t2.starttime < t1.starttime and t2.endtime >= t1.starttime) 
), 
endtimes as ----结束日期:去掉结束日期在日期范围内的数据
( select distinct name, endtime from @t as t1 where not exists (select * from @t as t2 where t2.name = t1.name and t2.endtime > t1.endtime and t2.starttime <= t1.endtime) 
) 
select name, starttime, (select min(endtime) from endtimes as e --结束日期取最小值where e.name = s.name and endtime >= starttime) as endtime 
from starttimes as s;

结果:

变形(过程相同,语句稍微有点不一样):

declare @t table (Name varchar(100),  starttime  datetime,  endtime datetime);
insert into @t values('A'   , '2017-01-02 00:00' , '2017-03-28 00:10'),('A'   , '2017-05-14 23:50' , '2017-05-29 23:50'),('B'   , '2017-05-18 00:00' , '2017-05-18 04:00'),('B'   , '2017-05-18 02:00' , '2017-05-18 03:00'),('C'   , '2017-01-02 00:00' , '2017-01-17 15:50'),('C'   , '2017-01-14 03:50' , '2017-01-28 15:50');--干掉起始点时间在某记录起止时间之间的
SELECT a.name,a.starttime
FROM @t a LEFT OUTER JOIN @t b
ON a.name=b.name and a.starttime>b.starttime AND a.starttime<=b.endtime GROUP BY a.name,a.starttime HAVING(COUNT(b.starttime)=0)--干掉终点时间在某记录起止时间之间的
SELECT a.name,a.endtime
FROM @t a LEFT OUTER JOIN @t b
ON a.name=b.name and a.endtime>=b.starttime AND a.endtime<b.endtime GROUP BY a.name,a.endtime HAVING COUNT(b.starttime)=0SELECT x.name,x.starttime,MIN(y.endtime)FROM
(SELECT a.name,a.starttime
FROM @t a LEFT OUTER JOIN @t bON a.name=b.name and a.starttime>b.starttime AND a.starttime<=b.endtime GROUP BY a.name,a.starttime HAVING(COUNT(b.starttime)=0)
) x INNER JOIN  (SELECT a.name,a.endtime FROM @t a LEFT OUTER JOIN @t bON a.name=b.name and a.endtime>=b.starttime AND a.endtime<b.endtime GROUP BY a.name,a.endtime HAVING COUNT(b.starttime)=0
) y ON x.name = y.name and x.starttime<=y.endtime GROUP BY x.name,x.starttime;

2.合并SQL中的时间重叠的记录方法:B

   起点和起点可以相同,终点和终点可以相同,去掉两值之间数据

declare @t table (Name varchar(100),  starttime  datetime,  endtime datetime);
insert into @t values('A'   , '2017-01-02 00:00' , '2017-03-28 00:10'),('A'   , '2017-05-14 23:50' , '2017-05-29 23:50'),('B'   , '2017-05-18 00:00' , '2017-05-18 04:00'),('B'   , '2017-05-18 02:00' , '2017-05-18 03:00'),('C'   , '2017-01-02 00:00' , '2017-01-17 15:50'),('C'   , '2017-01-14 03:50' , '2017-01-28 15:50');--剔除重复时间select d.Name,d.starttime,endtime=min(d.endtime) from (select a.name,a.starttime,b.endtime from @t a,@t b,@t cwhere a.endtime<=b.endtime and a.Name=b.Name and b.Name=c.Namegroup by a.name,a.starttime,b.endtimehaving(max(case when (a.starttime>c.starttime and a.starttime<=c.endtime) or (b.endtime>=c.starttime and b.endtime<c.endtime) then 1 else 0 end )=0)) dgroup by d.name,d.starttimeorder by d.Name,d.starttime

3.获取SQL中的时间重叠的记录

问题描述

时间重叠指上下两行数据的时间段有重叠部分,现在要找出这些在时间上有重叠的记录。

具体问题

有7个会议室,每个会议室每天都有人开会,某一天的开会时间如下:

查询出开会时间有重叠的是哪几个会议室?上面预期结果是 ID 2 3 4 5 6

问题分析

为了方便分析,我们画了如下一个草图来具体描述。

图中上面部分t和下面部分b有一段是重复的,分别是b.starttime到t.endtime部分。通过数学集合的思想,我们可以得出这个重叠部分的集合关系。

t.starttime<=b.endtime

AND t.endtime>=b.starttime

上面这个数学集合的重叠部分就是我们要的找的。

具体解法

--创建测试数据
WITH Meeting AS(
SELECT 1 ID,'08:00' Starttime,'09:15' Endtime
UNION ALL
SELECT 2,'13:20','15:20'
UNION ALL
SELECT 3,'10:00','14:00'
UNION ALL
SELECT 4,'13:55','16:25'
UNION ALL
SELECT 5,'14:00','17:45'
UNION ALL
SELECT 6,'14:05','17:45'
UNION ALL
SELECT 7,'18:05','19:45')--查询代码
SELECT DISTINCT b.* FROM Meeting t
JOIN Meeting b ON 
t.Starttime<=b.Endtime
AND t.Endtime>=b.Starttime
AND b.ID <> t.ID --排除与自身时间相等的值


http://chatgpt.dhexx.cn/article/SXqXi5hJ.shtml

相关文章

Java判断多个时间段是否重叠

因为项目需求用到比较给定时间段是否与已知时间段有重叠&#xff0c;所以写了一个比较简单易懂的方法&#xff0c;经测试可以满足本人目前的需求&#xff0c;大家如果发现该方法有什么问题可以提出来&#xff0c;如果有更好的方法也可以分享。 package com.demo;import java.u…

SQL中如何求解时间重叠的问题?

点击上方SQL数据库开发&#xff0c;关注获取SQL视频教程 SQL专栏 SQL数据库基础知识汇总 SQL数据库高级知识汇总 问题描述 时间重叠指上下两行数据的时间段有重叠部分&#xff0c;现在要找出这些在时间上有重叠的记录。 具体问题 有7个会议室&#xff0c;每个会议室每天都有人开…

多个日期时间段进行合并计算时长,剔除重叠时间段

多个日期时间段进行合并&#xff0c;算出经历的时长_itrytellyou的博客-CSDN博客_多个时间段合并多个日期时间段进行合并&#xff0c;算出经历的时长背景描述思路代码背景描述在公司进行人员描图模块开发时&#xff0c;涉及到了人员参会时长和参会次数的数据&#xff0c;比如一…

【js】判断时间段之间是否有重叠

一、需求 可以有多个时间段&#xff08;hh:mm&#xff09;&#xff0c;添加下一个时间段以及提交时需要判断各个时间段不能交叉&#xff0c;如下图&#xff1a; 一、方法 let dateAr [{ s: 02:00, e: 03:00 },{ s: 03:00, e: 04:01 },{ s: 05:00, e: 06:00 },{ s: 07:00, e:…

SQL中的时间重叠问题

点击关注上方“SQL数据库开发”&#xff0c; 设为“置顶或星标”&#xff0c;第一时间送达干货 SQL专栏 SQL基础知识第二版SQL高级知识第二版 问题描述 时间重叠指上下两行数据的时间段有重叠部分&#xff0c;现在要找出这些在时间上有重叠的记录。 具体问题 有7个会议室&#…

判断两个时间段交集、时间重叠问题

判断两个时间段范围是否有交集(时间重叠)问题经常遇到&#xff0c;比如预约会议室开会&#xff0c;活动的开始结束等&#xff0c;本文做此分析。 前提&#xff1a;本文时间传参已做限制&#xff0c;结束时间必须大于开始时间 1、正向思维 代码如下 (oneStartTime < other…

判断时间范围是否重叠(原理)

首先问题来源&#xff1a;因为业务需求需要在前端设置一个时间范围&#xff0c;并且可以多次增加&#xff0c;但要保证时间范围不重叠。某一个时间范围内做特定的事情。 让我们来分析一下时间重叠有几种情况 第一种情况&#xff1a;R1的开始时间在R2时间范围内 图① 第二种情…

企业物联网平台如何选择?

物联网平台的考虑因素都有哪些&#xff1f; 通常&#xff0c;物联网平台在安全功能、协议、数据格式、数据分析和可视化能力&#xff0c;以及所提供的应用环境方面进行比较。有很多物联网平台&#xff0c;它们可能拥有全套功能&#xff0c;但可能仍然无法胜任客户任务需求。一…

物联网技术,主要包括哪些核心技术

物联网的关键技术有识别和感知技术&#xff0c;网络与通信技术&#xff0c;数据挖掘与融合技术。 1.识别和感知技术 最常见的就是生活的的二维码了。 通过二维码&#xff0c;我们可以和图片&#xff0c;网址&#xff0c;软件&#xff0c;整个世界联系起来。 2.网络与通信技…

什么是物联网平台

1、什么是物联网平台 阿里云物联网平台为设备提供安全可靠的连接通信能力&#xff0c;向下连接海量设备&#xff0c;支撑设备数据采集上云&#xff1b;向上提供云端API&#xff0c;服务端通过调用云端API将指令下发至设备端&#xff0c;实现远程控制。 物联网平台消息通信流程…

物联网是什么,和互联网之间主要有什么区别

物联网概念最早可追溯到1990年&#xff0c;但当时并未引起重视。而随着互联网的普及、科技的发展&#xff0c;物联网在近年来备受关注&#xff0c;并成为一个新经济增长点的战略新兴产业。 物联网(InternetofThings)&#xff0c;顾名思义就是"物物相连的互联网";更为…

物联网的应用领域有哪些?

智能仓储 目前&#xff0c;国内最成熟的智能仓储解决方案智能仓储解决方案&#xff0c;智能仓储是物流过程的一个环节&#xff0c;智能仓储的应用&#xff0c;保证了货物仓库管理各个环节数据输入的速度和准确性&#xff0c;确保企业及时准确地掌握库存的真实数据&#xff0c;…

物联网的组成包含哪些

物联网采集到的信息常常需要直接报警或者是经过计算机处理后报警&#xff0c;常见的报警形式有声、光、电&#xff08;电话、短信&#xff09;。当所选参数偏离预先设定的限度值时能进行报警的系统。 物联网的组成包含哪些 物联网大致可以分为以下四个层面&#xff0c;即&#…

物联网技术主要有哪些,目前都应用在哪些领域?

现在看这篇文章的你&#xff0c;是在用什么方式阅读这篇文章&#xff1f;是通过手机&#xff1f;还是通过电脑&#xff1f;还是平板电脑呢&#xff1f;无论您是用什么设备&#xff0c;它都是联网的。 互联网的出现是一件非常美好的事情&#xff0c;它为我们提供了以前不可能实…

物联网十大应用场景

1 智慧物流 智慧物流是新技术应用于物流行业的统称&#xff0c;指的是以物联网、大数据、人工智能等信息技术为支撑&#xff0c;在物流的运输、仓储、包装、装卸、配送等各个环节实现系统感知、全面分析及处理等功能。智慧物流的实现能大大地降低各行业运输的成本&#xff0c;…

物联网主要应用领域

一、物联网在智慧物流领域应用 &#xff08;1&#xff09;应用阶段&#xff1a; 启蒙阶段&#xff08; 2003~2004&#xff09;->起步发展与探索阶段&#xff08; 2005~2009&#xff09;->理念提升阶段 &#xff08; 2009~&#xff0c;形成三大核心技术&#xff1a;感知技…

物联网主要应用在哪些领域

随着物联网的快速发展&#xff0c;物联网在生活中的应越来越广。那么&#xff0c;物联网主要应用在哪些领域&#xff1f;下面简要谈谈物联网在工作和生活中的应用。 1、消费者物联网 随着苹果、谷歌和三星等公司将业务延伸到可穿戴设备、智能家居、汽车等领域&#xff0c;它们将…

了解物联网

物联网&#xff08;IoT&#xff0c;Internet of Things&#xff09;在互联网的基础上&#xff0c;将用户端延伸和扩展到物与物、物与人的连接。物联网模式中&#xff0c;所有物品与网络连接&#xff0c;并进行通信和场景联动。 物联网是互联网的外延。互联网通过电脑、移动终端…

什么是物联网技术?物联网主要技术有哪些?

如今&#xff0c;物联网在人们的工作和生活中&#xff0c;出现的频次越来越高。物联网技术&#xff08;Internet of Things&#xff0c;IoT&#xff09;起源于传媒领域&#xff0c;是信息科技产业的第三次革命。物联网是指通过信息传感设备&#xff0c;按约定的协议&#xff0c…

物联网的优势在哪里

随着技术相继融入我们的生活&#xff0c;我们生活、工作和与世界互动的方式也逐渐发生了改变。虽然我们可能没有意识到这一点&#xff0c;但我们周围连网设备数量却以指数级速度不断增加&#xff0c;而这些连网设备被称之为“物联网”。 简单地说&#xff0c;物联网的目的就是…