在层次查询中,Oracle引入了一个伪列level,用来表示当前行(节点)对应的level, 
它从1开始计数,每多一层level的值就加1。 
我们可以据此实现对两个日期/整数之间所有日期/整数的遍历。 
---------------------------------------------------------- 
SQL> create table test (begin_date date,end_date date);

Table created

SQL> insert into test values(trunc(sysdate),trunc(sysdate+5));

1 row inserted

SQL> select * from test;

BEGIN_DATE  END_DATE 
----------- ----------- 
2010-4-6    2010-4-11

SQL> select begin_date,end_date,begin_date+level -1 as today 
  2  from test 
  3  connect by begin_date + level -1 <= end_date;

BEGIN_DATE  END_DATE    TODAY 
----------- ----------- ----------- 
2010-4-6    2010-4-11   2010-4-6 
2010-4-6    2010-4-11   2010-4-7 
2010-4-6    2010-4-11   2010-4-8 
2010-4-6    2010-4-11   2010-4-9 
2010-4-6    2010-4-11   2010-4-10 
2010-4-6    2010-4-11   2010-4-11

6 rows selected

------------------------------------------------------------------插入两条记录,看该查询语句是否可行 
SQL> insert into test values(trunc(sysdate+4),trunc(sysdate+7));

1 row inserted

SQL> select * from test;

BEGIN_DATE  END_DATE 
----------- ----------- 
2010-4-6    2010-4-11 
2010-4-10   2010-4-13

SQL> select distinct begin_date+level-1 as today 
  2  from test 
  3  connect by begin_date+level-1 <= end_date;

TODAY 
----------- 
2010-4-7 
2010-4-13 
2010-4-8 
2010-4-11 
2010-4-9 
2010-4-6 
2010-4-10 
2010-4-12

8 rows selected 
--------------------------------------- 根据最大和最小值得查询 
SQL> delete from test where begin_date = to_date('2010-4-10','yyyy-mm-dd');

1 row deleted

SQL> select * from test;

BEGIN_DATE  END_DATE 
----------- ----------- 
2010-4-6    2010-4-11

SQL> SELECT one_date 
  2    FROM (SELECT start_date + level - 1 one_date 
  3            FROM (SELECT min(begin_date) start_date, max(end_date) end_date 
  4                    FROM test) test 
  5          connect BY start_date + level - 1 <= end_date ) all_date, 
  6         test 
  7   WHERE one_date BETWEEN begin_date AND end_date;

ONE_DATE 
----------- 
2010-4-6 
2010-4-7 
2010-4-8 
2010-4-9 
2010-4-10 
2010-4-11

6 rows selected

如何用SQL返回两个日期之间的所有连续日期的更多相关文章

  1. sql返回两个日期之间的日期_函数实现

    -- Description:返回两段日期之间的所有日期    <Description,,>-- ============================================ ...

  2. SQL 获得两个时间段之间的数据

    一般保存在数据库中的日期精度很高,比如'2014-04-15 16:31:22.000' 而一般用户选择的时间精度是精确到日的,比如'2012-04-15' 所以你想取出两个日期之间的数据,如果用下面 ...

  3. 日期选择时两个日期之间的动态控制--My97datepicker日期选择控件

    实现效果:如果先选离店日期,再选入住日期的话,入住日期大于离店日期则离店日期+1天否则离店日期不变,先选入店再选离店离店,离店只能选之后的日期,且两个日期之间最多间隔88天 <div class ...

  4. JS之document例题讲解1(两张表之间数据转移、日期时间选择、子菜单下拉、用div做下拉菜单、事件总结)

    作业一:两个列表之间数据从一个列表移动到另一个列表 <div style="width:600px; height:500px; margin-top:20px"> & ...

  5. SQL生成两个时间之间的所有日期

    select dateadd(dd,number,'2012-1-1') AS date from master..spt_values where type='p' and dateadd(dd,n ...

  6. sql 截取两个字符串之间的字符

    select SUBSTRING(templatepath,CHARINDEX('/',templatepath)+1,CHARINDEX('.', templatepath)-CHARINDEX(' ...

  7. sql计算两个时间之间的差,并用时分秒表示

    这是自己写的方法,总觉得会有更好的办法实现这个效果呢? SELECT then ))))+'秒' then )))+'秒' then ))+'秒' else CONVERT(nvarchar,DATE ...

  8. MySQL如何查询两个日期之间的记录

    baidu出来的结果多是下面答案:<quote> MySQL中,如何查询两个日期之间的记录,日期所在字段的类型为datetime(0000-00-00 00:00:00) 解决方案: 直接 ...

  9. Oracle常用函数:DateDiff() 返回两个日期之间的时间间隔自定义函数

    首先在oracle中没有datediff()函数可以用以下方法在oracle中实现该函数的功能:1.利用日期间的加减运算天:ROUND(TO_NUMBER(END_DATE - START_DATE) ...

随机推荐

  1. [SAP ABAP开发技术总结]DIALOG屏幕流逻辑

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  2. 用iconv指令解决utf8和gb18030编码间转换

    Linux显示在Windows编辑过的中文就会显示乱码是由于两个操作系统使用的编码不同所致.Linux下使用的编码是utf8,而Windows使用的是gb18030.  解决方案:  在终端中,进入到 ...

  3. 使用httpclient时候,出现“Too many open files”问题

    最近接触的sendHttpPostRequest的问题比较多,近期碰到了关于 "java.net.SocketException: Too many open files" 的问题 ...

  4. 可以考虑使用SublimeText编辑器替代notepad++了

    大概是去年吧,这款编辑器神一般的出现在我面前,经过我小心翼翼的试用后发现并不是那么太顺手,插件配置都不太成熟,如Package Control. 最喜欢用它的zencoding还得专门开个小窗:ang ...

  5. Shell Sort(草稿)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Shel ...

  6. underscore的封装和扩展

    // 1. 不污染全局环境 (function() { // 2. 保留之前同名变量 var previousUnderscore = window._; var _ = function(obj) ...

  7. unity3d vs2012

    Unity3D自带的MonoDevelop编辑器无论是js还是c#代码提示都很差,很诡异的就是变量名和方法名有的时候提示有的时候不提示.不过用Visual Studio代替MonoDevelop这个问 ...

  8. ubuntu 安装JDK

    下载JDK6安装包,我的为32位系统所以选择jdk-6u35-linux-i586.bin 下载地址:http://www.oracle.com/technetwork/java/javase/dow ...

  9. 坐标随鼠标移动 jquery简易版

    <html> <span style="position:absolute" id="xy_test"></span> &l ...

  10. iOS - Swift NSDate 时间

    前言 NSDate public class NSDate : NSObject, NSCopying, NSSecureCoding NSDate 用来表示公历的 GMT 时间(格林威治时间).是独 ...