0

0

atitit.判断时间重叠方法总结javac++c#.netjsphp

php中文网

php中文网

发布时间:2016-06-07 16:10:54

|

1628人浏览过

|

来源于php中文网

原创

atitit.判断时间重叠方法总结 java c++ c#.net js php 1. 判断时间重叠具体流程思路 1 2. 重叠算法 实际上就是日期集合跟个时间集合的的交集(乘法算法) 1 3. 代码--- 1 4. 最终生成的sql 3 5. 参考 5 1. 判断时间重叠具体流程思路 先判断日期重叠,在判断时

atitit.判断时间重叠方法总结 java c++ c#.net js php

 

1. 判断时间重叠具体流程思路 1

2. 重叠算法 实际上就是日期集合跟个时间集合的的交集(乘法算法) 1

3. 代码--- 1

立即学习PHP免费学习笔记(深入)”;

4. 最终生成的sql 3

5. 参考 5

 

1. 判断时间重叠具体流程思路

先判断日期重叠,在判断时间区段重叠。

蚂蚁PPT
蚂蚁PPT

AI在线智能生成PPT

下载

每个区段都有内包含,外包含,左包含,右包括...所以,or表达式需要4*4=16个..每个or 表达式包括4个and表达式( 两个日期表达式,两个时间范围表达式)

最终的最终的的表达式需要16*4=64个,,比较长的了..

 

2. 重叠算法 实际上就是日期集合跟个时间集合的的交集(乘法算法)

在程序设计里有。。。。。

回答

那实际上就是交、并、差。
所谓加,实际上就是求两个集合的并集
减,就是求两个集合的差集
乘,就是求两个集合的并集
它们都是从逻辑的运算推出来的

另外更正一下:乘是求两个集合的交集。

 

 

3. 代码---

private void ini() {

String db_start_fld = "start_time";

String db_end_fld = "end_time";



String db_include_exp = "db_start_fld>=ui_start and db_end_fld<=ui_end ";

String db_outclude_exp = "db_start_fld<=ui_start and db_end_fld>=ui_end ";

String db_leftinclude_exp = "db_end_fld>=ui_start and db_end_fld <=ui_end ";

String db_ritinclude_exp = "db_start_fld>=ui_start and db_end_fld<=ui_end ";









List dateExpList = new ArrayList() {

{



add(expandFunc(db_include_exp));

add(expandFunc(db_outclude_exp));

add(expandFunc(db_leftinclude_exp));

add(expandFunc(db_ritinclude_exp));



}



private String expandFunc(String db_include_exp) {

String db_start_fld_Datefunc = " CONVERT(varchar(100), db_start_fld, 23)";

String db_end_fld_Datefunc = " CONVERT(varchar(100), db_end_fld, 23)";

return db_include_exp.replaceAll("db_start_fld",

db_start_fld_Datefunc).replaceAll("db_end_fld",

db_end_fld_Datefunc);

}

};





List timeExpList = new ArrayList() {

{

add(expandFunc(db_include_exp));

add(expandFunc(db_outclude_exp));

add(expandFunc(db_leftinclude_exp));

add(expandFunc(db_ritinclude_exp));



}



private String expandFunc(String db_include_exp) {

String db_start_fld_Timefunc = " CONVERT(varchar(100), db_start_fld, 8)";

String db_end_fld_Timefunc = " CONVERT(varchar(100), db_end_fld, 8)";

return db_include_exp.replaceAll("db_start_fld",

db_start_fld_Timefunc).replaceAll("db_end_fld",

db_end_fld_Timefunc);

}

};



List finalList= new ArrayList() {{



for (String dateExp : dateExpList) {

for (String timeExp : timeExpList) {

this.add(dateExp+" and "+timeExp.replaceAll("db_start_fld", db_start_fld).replaceAll("db_end_fld", db_end_fld));

}

}



}};



String sql=new ArrayList(){

private String exec( ) {

String exp_final=" 1=1 ";

for (String exp : finalList) {

//if(exp_final.length()==0)

exp_final=exp_final + " or ( "+exp +" ) ";

}

return exp_final;



}}.exec( );

System.out.println(sql);





}

4. 最终生成的sql


SELECT *

FROM tab

WHERE 1=1

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), start_time, 8)<=ui_start

AND CONVERT(varchar(100), end_time, 8)>=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), end_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8) <=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)<=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)>=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)<=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)>=ui_end

AND CONVERT(varchar(100), start_time, 8)<=ui_start

AND CONVERT(varchar(100), end_time, 8)>=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)<=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)>=ui_end

AND CONVERT(varchar(100), end_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8) <=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)<=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)>=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_end_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23) <=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_end_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23) <=ui_end

AND CONVERT(varchar(100), start_time, 8)<=ui_start

AND CONVERT(varchar(100), end_time, 8)>=ui_end)

OR (CONVERT(varchar(100), db_end_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23) <=ui_end

AND CONVERT(varchar(100), end_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8) <=ui_end)

OR (CONVERT(varchar(100), db_end_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23) <=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), start_time, 8)<=ui_start

AND CONVERT(varchar(100), end_time, 8)>=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), end_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8) <=ui_end)

OR (CONVERT(varchar(100), db_start_fld, 23)>=ui_start

AND CONVERT(varchar(100), db_end_fld, 23)<=ui_end

AND CONVERT(varchar(100), start_time, 8)>=ui_start

AND CONVERT(varchar(100), end_time, 8)<=ui_end)

 

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

55

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.7万人学习

Midjourney基础课程
Midjourney基础课程

共16课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号