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

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

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

3. 代码--- 1

4. 最终生成的sql 3

5. 参考 5

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的更多相关文章

  1. JAVA 导出 Excel, JS 导出 Excel

    本介绍两种Excle导出方法: JAVA 导出 Excle, JS 导出 Excle 1, js 根据 html 页面的 table > tr > td 标签导出 js代码: //导出 v ...

  2. atitit.技术选型方法总结为什么java就是比.net有前途

    atitit.技术选型方法总结为什么java就是比.net有前途 #----按照不同的需要有不铜的法... 一般有开发效率,稳定性上的需要.. 作者 老哇的爪子 Attilax 艾龙,  EMAIL: ...

  3. Atitit 判断判断一张图片是否包含另一张小图片

    Atitit 判断判断一张图片是否包含另一张小图片 1. keyword1 2.  模板匹配是在图像中寻找目标的方法之一(切割+图像相似度计算)1 3. 匹配效果2 4. 图片相似度的算法(感知哈希算 ...

  4. atitit.api设计 方法 指南 手册 v2 q929.docx

    atitit.api设计 方法 指南 手册 v2 q929.docx atitit.api设计原则与方法 1. 归一化(锤子钉子理论)1 1.1. 链式方法2 1.2. 规则5:建立返回值类型2 1. ...

  5. Atitit.编程语言原理---方法重载的实现与设计 调用方法的原理

    Atitit.编程语言原理---方法重载的实现与设计 调用方法的原理 1. 重载包括:普通方法的重载和构造方法的重载 1 1.1. 横向重载”和“纵向重载”1 1.2. 方法签名通过  方法名称,参数 ...

  6. Atitit 图像处理 调用opencv 通过java  api   attilax总结

    Atitit 图像处理 调用opencv 通过java  api   attilax总结 1.1. Opencv java api的支持 opencv2.4.2 就有了对java api的支持1 1. ...

  7. Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结

    Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结 1.1. 边缘检测的基本方法Canny最常用了1 1.2. 编写matlab边缘检测代码, ...

  8. Atitit  深入理解命名空间namespace  java c# php js

    Atitit  深入理解命名空间namespace  java c# php js 1.1. Namespace还是package1 1.2. import同时解决了令人头疼的include1 1.3 ...

  9. atitit.架构设计---方法调用结果使用异常还是返回值

    atitit.架构设计---方法调用结果使用异常还是返回值 1. 应该返回BOOL类型还是异常 1 2. 最终会有四种状况,抛出异常.返回特殊值.阻塞.超时 1 3. 异常的优缺点点 1 4. jav ...

随机推荐

  1. 关于Gson在强转时的ClassCastException

    关于Gson的坑人指出: 将list转化为json String beanListToJson = gson.toJson(list, type); 将json还原为list List<T &g ...

  2. [翻译] SFRoundProgressCounterView 带有进度显示的倒计时视图

    SFRoundProgressCounterView 带有进度显示的倒计时视图 https://github.com/simpliflow/SFRoundProgressCounterView A c ...

  3. iOS中 imageNamed方法 非常多图片占用大量内存问题

    当我们须要载入非常多图片(相冊)的时候我们通常会用[UIimage  imageNamed:imageName]; 实际上[UIimage  imageNamed:imageName]这种方法在图片使 ...

  4. Hibernate中@Embedded和@Embeddable注解

    在使用实体类生成对应的数据库表时,很多的时候都会遇到这种情况:在一个实体类中引用另外的实体类,一般遇上这种情况,我们使用@OneToOne.@OneToMany.@ManyToOne.@ManyToM ...

  5. [Android Pro] Android应用性能测试之CPU和内存占用(转载)

    首先稍做分析一下测试环境:我们知道CPU和内存占用是一个实时变化的状态,而市面上还没有具体的哪款android应用能做到实时监控CPU和内存占用并使用log日志保存.考虑到android的底层框架是基 ...

  6. Python验证码识别处理实例

    一.准备工作与代码实例 1.PIL.pytesser.tesseract (1)安装PIL:下载地址:http://www.pythonware.com/products/pil/(CSDN下载) 下 ...

  7. Python 字符串前面加'r'

    在Python的string前面加上‘r’, 是为了告诉编译器这个string是个raw string,不要转意backslash '\' . 例如,\n 在raw string中,是两个字符,\和n ...

  8. PostgreSQL源码分析之shared buffer与磁盘文件

    我们知道,PostgreSQL数据库中的信息,最终是要写入持久设备的.那么PostgreSQL是怎么将信息组织存储在磁盘上的呢? Bruce Momjian有一个slide <Insider P ...

  9. MyEclipse 全面的快捷键

    摘自: http://www.360doc.com/content/11/0406/10/6704374_107513559.shtml 引用 MyEclipse快捷键(全面) 程序代码自动排版:Ct ...

  10. -bash: ./xxx.sh: /bin/bash^M: bad interpreter: No such file or directory

    问题的原因是在windows下编辑然后上传到linux系统里执行的..sh文件的格式为dos格式.而linux只能执行格式为unix格式的脚本. 不要使用记事本编辑,使用代码编辑器可以正常执行