atitit.判断时间重叠方法总结 java c++ c#.net js php
atitit.判断时间重叠方法总结 java c++ c#.net js php
2. 重叠算法 实际上就是日期集合跟个时间集合的的交集(乘法算法) 1
1. 判断时间重叠具体流程思路
先判断日期重叠,在判断时间区段重叠。
每个区段都有内包含,外包含,左包含,右包括...所以,or表达式需要4*4=16个..每个or 表达式包括4个and表达式( 两个日期表达式,两个时间范围表达式)
最终的最终的的表达式需要16*4=64个,,比较长的了..
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax
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<String> dateExpList = new ArrayList<String>() {
{
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<String> timeExpList = new ArrayList<String>() {
{
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<String> finalList= new ArrayList<String>() {{
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)
5. 参考
java 时间段重合时间差 - 天才少年程序员-李荣盛专栏 - 博客频道 - CSDN.NET
JAVA中如何判断两个时间段是否有交集-CSDN论坛-CSDN.NET-中国最大的IT技术社区
比较两个日期间隔是否有碰撞的工具类,判断两个时间区间是否有交集(单位天) Java - 和申的日志 - 网易博客
atitit.判断时间重叠方法总结 java c++ c#.net js php的更多相关文章
- JAVA 导出 Excel, JS 导出 Excel
本介绍两种Excle导出方法: JAVA 导出 Excle, JS 导出 Excle 1, js 根据 html 页面的 table > tr > td 标签导出 js代码: //导出 v ...
- atitit.技术选型方法总结为什么java就是比.net有前途
atitit.技术选型方法总结为什么java就是比.net有前途 #----按照不同的需要有不铜的法... 一般有开发效率,稳定性上的需要.. 作者 老哇的爪子 Attilax 艾龙, EMAIL: ...
- Atitit 判断判断一张图片是否包含另一张小图片
Atitit 判断判断一张图片是否包含另一张小图片 1. keyword1 2. 模板匹配是在图像中寻找目标的方法之一(切割+图像相似度计算)1 3. 匹配效果2 4. 图片相似度的算法(感知哈希算 ...
- atitit.api设计 方法 指南 手册 v2 q929.docx
atitit.api设计 方法 指南 手册 v2 q929.docx atitit.api设计原则与方法 1. 归一化(锤子钉子理论)1 1.1. 链式方法2 1.2. 规则5:建立返回值类型2 1. ...
- Atitit.编程语言原理---方法重载的实现与设计 调用方法的原理
Atitit.编程语言原理---方法重载的实现与设计 调用方法的原理 1. 重载包括:普通方法的重载和构造方法的重载 1 1.1. 横向重载”和“纵向重载”1 1.2. 方法签名通过 方法名称,参数 ...
- Atitit 图像处理 调用opencv 通过java api attilax总结
Atitit 图像处理 调用opencv 通过java api attilax总结 1.1. Opencv java api的支持 opencv2.4.2 就有了对java api的支持1 1. ...
- Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结
Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结 1.1. 边缘检测的基本方法Canny最常用了1 1.2. 编写matlab边缘检测代码, ...
- Atitit 深入理解命名空间namespace java c# php js
Atitit 深入理解命名空间namespace java c# php js 1.1. Namespace还是package1 1.2. import同时解决了令人头疼的include1 1.3 ...
- atitit.架构设计---方法调用结果使用异常还是返回值
atitit.架构设计---方法调用结果使用异常还是返回值 1. 应该返回BOOL类型还是异常 1 2. 最终会有四种状况,抛出异常.返回特殊值.阻塞.超时 1 3. 异常的优缺点点 1 4. jav ...
随机推荐
- cas忽略地址配置
项目中需要忽略部分地址不需要cas验证,网上资料不多,结合cas源码,找到了配置方法:web.xml中增加ignorePattern配置.实际上是通过正则表达式来匹配. <filter> ...
- iOS开源项目:PullToRefresh
PullToRefresh实现了类似微博下拉刷新的功能:https://github.com/sonnyparlin/PullToRefresh 首先把PullToRefreshView.h, Pul ...
- linux、mac的bash和zsh如何切换
1.hostname 192-23-2-2 修改主机名字 2.chsh -s /bin/bash和chsh -s /bin/zsh可以永久切换,也就是一登录进来的就是相应的界面 bash/zsh命令是 ...
- mysql的日志管理
日志操作是数据库维护中最重要的手段之一,日志文件会记录MySQL服务器的各种信息,所以当MySQL服务器遭到意外损坏时,不仅可以通过日志文件来查看出错的原因,而且还可以通过日志文件进行数据恢复. MY ...
- 基于java语言的给cube添加custom view来实现权限控制
今天是农历2014年的最后一个工作日了,在这里提前祝大家新年快乐.羊年大吉!当然本人今天也拿出来点儿真东西,做为献给大家的新年礼物,依次共勉. 下文主要讲述的是使用Java代码来完成对cube基于部门 ...
- win8.1安装开发工具 vs2015 Visual Studio 2015 Preview Downloads
1.首先全新安装win8.1 略 破解激活.... 2.安装Visual Studio 2015 Visual Studio 2015 是免费的,不存在破解版本, 如果安装过程中存在问题,建议先把本文 ...
- JQuery 控制div滚动条保持最下
$("#session_show").animate({ scrollTop: $("#session_show").scrollHeight },1000); ...
- Cocos2d-x -- 如何让背景从上到下滚动
1. 首先,声明一个2个大小的sprite数组 class GameScreen : public cocos2d::Layer { public: ... cocos2d::Sprite *back ...
- 软件开发工具GCC
重点掌握以下知识点: 了解gcc编译器的下载和安装方法,包括嵌入式交叉编译平台搭建的方法 重点掌握gcc的基本编译流程和编译方法 重点掌握gcc编译的高级操作及选项 了解gcc编译器性能分析工具,包括 ...
- 【转发】Visual Studio 2013 如何关闭调试而不关闭IIS Express
在VS主面板打开:工具->选项->调试->编辑继续 取消选中[启用"编辑并继续"] 就OK了 (英文版的请对应相应的操作) 不过这是针对所有的调试,如果你想针 ...