sqlserver 各种集合、区间、 时间轴(持更)

1.所有有交集的区间

场景:在事件表里查找某年员工的岗位系数,并计算其加权平均数。case1:该员工是老员工,从2020年一直到2049年。case2:该员工是老员工,但是今年离职。case3:该员工是今年的新员工,今年入职,今年离职。case4:该员工是今年的新员工,一直在职。case5:该员工是今年的新员工,未来离职。

sql 复制代码
select * from A where datediff(MINUTE,FromDate,CONVERT(CHAR(5),{TERM},120)+'12-31')>0 and datediff(MINUTE ,CONVERT(CHAR(5),{TERM},120)+'01-01' ,ToDate )>0 

2.部分有交集

场景:

sql 复制代码
 select * from  A where ((datediff(MINUTE,@begintime,endtime)>0  and datediff(MINUTE ,BeginTime ,@BeginTime )>0)
				or (  datediff(MINUTE,@EndTime ,endtime)>0  and datediff(MINUTE ,BeginTime ,@EndTime )>0 ))

3.只有子集

场景:

sql 复制代码
select * from A where @BeginTime>BeginTime And EndTime>@EndTime

4.没交集

场景:

sql 复制代码
select * from A Where @BeginTime>a.EndTime
			Or BeginTime>@EndTime

5.取交集外的部分

场景

sql 复制代码
	Select 
		Case When b.BeginTime Between a.BeginTime And a.EndTime And b.EndTime>=a.EndTime Then a.BeginTime Else b.EndTime End
		,Case When a.BeginTime Between b.BeginTime And b.EndTime And a.EndTime>=b.EndTime Then a.EndTime Else b.BeginTime End
from A a,B b		
	Where (a.BeginTime<>b.BeginTime Or a.EndTime<>b.EndTime)
		And ((b.BeginTime Between a.BeginTime And a.EndTime And b.EndTime>=a.EndTime)
			Or (a.BeginTime Between b.BeginTime And b.EndTime And a.EndTime>=b.EndTime))
		And Case When b.BeginTime Between a.BeginTime And a.EndTime And (b.EndTime>=a.EndTime) Then a.BeginTime Else b.EndTime End
			<Case When a.BeginTime Between b.BeginTime And b.EndTime And (a.EndTime>=b.EndTime) Then a.EndTime Else b.BeginTime End

6.取交集部分

场景

sql 复制代码
	Select Case When b.BeginTime Between a.BeginTime And a.EndTime And b.EndTime>=a.EndTime Then b.begintime Else a.begintime End
	,Case When a.BeginTime Between b.BeginTime And b.EndTime And a.EndTime>=b.EndTime Then a.endtime Else b.endtime End
From A a,B b
Where (a.BeginTime<>b.BeginTime Or a.EndTime<>b.EndTime)
	And ((b.BeginTime Between a.BeginTime And a.EndTime And b.EndTime>=a.EndTime)
		Or (a.BeginTime Between b.BeginTime And b.EndTime And a.EndTime>=b.EndTime))
	And Case When b.BeginTime Between a.BeginTime And a.EndTime And (b.EndTime>=a.EndTime) Then a.BeginTime Else b.EndTime End
		<Case When a.BeginTime Between b.BeginTime And b.EndTime And (a.EndTime>=b.EndTime) Then a.EndTime Else b.BeginTime End

7.一般的取交集(左端都要取最大,右端取最小)

场景:

复制代码
Select 
	Case When BeginDate<@BeginDate Then @BeginDate Else BeginDate End,		
	Case When EndDate>@EndDate Then @EndDate Else EndDate End
相关推荐
Dontla几秒前
Audit Log(审计日志)介绍(对系统中关键操作行为记录,用户行为+系统变更+安全事件)中间件 / AOP、数据库层——数据库变更捕获(CDC)
数据库·中间件
a951141642几秒前
Redis如何利用Redisson处理并发击穿
jvm·数据库·python
_Evan_Yao几秒前
当AI能写SQL时,数据库表设计反而成了最后一道护城河
数据库·人工智能·后端·sql
2401_887724506 分钟前
如何防止SQL注入利用存储过程_确保存储过程不拼字符串.txt
jvm·数据库·python
Aray12349 分钟前
Redis服务端分片(Redis Cluster)详解
数据库·redis·缓存
m0_7164300712 分钟前
Laravel 迁移中外键约束错误的成因与修复方案.txt
jvm·数据库·python
2201_7568473313 分钟前
CSS如何利用CSS变量管理间距_统一定义盒模型数值
jvm·数据库·python
Greyson113 分钟前
PHP怎么用array_unique去重数组元素【方法】.txt
jvm·数据库·python
weixin_5806140014 分钟前
Bootstrap制作后台管理系统布局 Bootstrap如何搭建Dashboard框架.txt
jvm·数据库·python
吕源林16 分钟前
mysql慢查询如何自动捕获_配置slow_query_log与慢查询分析工具
jvm·数据库·python