-- Create table

create table TEMP_CALENDAR

(

  MONTH VARCHAR2(6),

  W_7   VARCHAR2(2),

  W_1   VARCHAR2(2),

  W_2   VARCHAR2(2),

  W_3   VARCHAR2(2),

  W_4   VARCHAR2(2),

  W_5   VARCHAR2(2),

  W_6   VARCHAR2(2),

  WEEK  VARCHAR2(20)

) ;

-- Add comments to the table 

comment on table TEMP_CALENDAR

  is '日期源数据表';

-- Add comments to the columns 

comment on column TEMP_CALENDAR.MONTH

  is '月份(格式如:200801)';

comment on column TEMP_CALENDAR.W_7

  is '周日的日期(如:06)';

comment on column TEMP_CALENDAR.W_1

  is '周一(如:07)';

comment on column TEMP_CALENDAR.W_2

  is '周二(如:08)';

comment on column TEMP_CALENDAR.W_3

  is '周三(如:09)';

comment on column TEMP_CALENDAR.W_4

  is '周四(如:10)';

comment on column TEMP_CALENDAR.W_5

  is '周五(如:11)';

comment on column TEMP_CALENDAR.W_6

  is '周六(如:12)';

comment on column TEMP_CALENDAR.WEEK

  is '本月第几周';

----生成 日历信息 

-- truncate table calendar; 

declare 





    vi_begin_year number(6); 

    vi_end_year number(6); 

    vi_year number(6); 

    vi_month number(6); 

    vs_month varchar2(6); 

    vs_first_day varchar2(8); 









begin 





    vi_begin_year :=2000; ---start year

    vi_end_year :=2100;   --- end year

    vi_month :=1; 

    vi_year := vi_begin_year; 





loop exit when(vi_year > vi_end_year);

 for i in 1..12 loop 

     if length(i) =1 then 

        vs_month := to_char(vi_year)||'0'||to_char(i); 

     else

         vs_month := to_char(vi_year)||to_char(i); 

     end if;

     

  vs_first_day := vs_month||'01'; 

  

  insert into temp_calendar ( month, week,w_7, w_1, w_2, w_3, w_4, w_5, w_6 ) 

  

  select substr(vs_first_day,1,6) month, 

  ceil((to_char(everyday,'dd')+(to_char(to_date(vs_first_day,'yyyymmdd'),'d')-1))/7) as week, 

  sum(decode(to_char(everyday,'dy'),'星期日',to_char(everyday,'dd'))) as 星期日, 

  sum(decode(to_char(everyday,'dy'),'星期一',to_char(everyday,'dd'))) as 星期一, 

  sum(decode(to_char(everyday,'dy'),'星期二',to_char(everyday,'dd'))) as 星期二, 

  sum(decode(to_char(everyday,'dy'),'星期三',to_char(everyday,'dd'))) as 星期三, 

  sum(decode(to_char(everyday,'dy'),'星期四',to_char(everyday,'dd'))) as 星期四, 

  sum(decode(to_char(everyday,'dy'),'星期五',to_char(everyday,'dd'))) as 星期五, 

  sum(decode(to_char(everyday,'dy'),'星期六',to_char(everyday,'dd'))) as 星期六 

  from(

    select to_date(vs_first_day,'yyyymmdd') + level - 1 as everyDay 

    from dual 

    connect by level <= (last_day(to_date(vs_first_day,'yyyymmdd')) 

    - to_date(vs_first_day,'yyyymmdd') +1) ) 

  group by ceil((to_char(everyday,'dd')+(to_char(to_date(vs_first_day,'yyyymmdd'),'d')-1))/7) ; 

  

  

  commit; 

  

  end loop; 

  

  vi_year := vi_year+1; 

  

end loop; 

  

  end;

  order by a.year,a.month, a.week;

oralce sql 创建指定时间段内的日历信息的更多相关文章

  1. sql取指定时间段内的所有月份

    declare @begin datetime,@end datetime set @begin='2017-01-01' set @end='2019-03-04' declare @months ...

  2. sqlServer通过指定的起始时间,创建该时间段内以年、月、日为时间段的临时表

    通过指定的起始时间,创建该时间段内以年.月.日为时间段的临时表 ALTER PROCEDURE [dbo].[YOUR_SP_Name]     -- Add the parameters for t ...

  3. 趣味SQL——创建指定的数据类型

    原创作品,出自 "深蓝的blog" 博客,深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/46908843 趣味 ...

  4. SQL Server备份时间段内插入的数据依旧进入了备份文件?(转载)

    问 MSSql我在本机测试了下.为了延长备份时间,找个大的数据库.开始完整备份bak然后再此库新建表,并增添数据.备份结束.==================还原备份后,在还原的数据库内发现新增的表 ...

  5. shell查找指定时间段内的文件

    #!/bin/bash#20170905 输入参数格式echo "显示"$1"的备份文件"date_0=$1date_1=`expr $date_0 + 1`d ...

  6. SQL Server中获取指定时间段内的所有日期

    DECLARE @days INT, @date_start DATETIME = '2016-11-01', @date_end DATETIME = '2016-11-10' SET @days ...

  7. 数据库SQL语句查询指定时间段内的数据

    [摘要]有的时候,我们需要查询数据库某段时间之间的数据,比如2016年5月1号到到5月3号之间用户注册数量(特殊节假日期间)等.那么用SQL语句如何实现呢? 首先,数据表中的存时间的字段比如是addt ...

  8. SQL Server中获取指定时间段内的所有月份

    例如查询 2012-1-5 到 2012-11-3 之间所有的月份 declare @begin datetime,@end datetime set @begin='2012-1-5' set @e ...

  9. SQL Server 查询时间段内数据

    方式一: ALTER Proc [dbo].[usp_Rpt_AcctTypeAudit] @FromDate datetime=null, -- yyyy-mm-dd (may change in ...

随机推荐

  1. [Apple开发者帐户帮助]五、管理标识符(1)注册应用程序ID

    一个应用程序ID标识的配置设定档中的应用程序.它是一个由两部分组成的字符串,用于标识来自单个开发团队的一个或多个应用程序.有两种类型的应用程序ID:用于单个应用程序的显式应用程序ID,以及用于一组应用 ...

  2. Mvc程序字体加载失败问题

    在我们开发的asp.net-mvc项目中,有时会出现字体加载失败的现象,但是一检查字体文件目录,发现文件目录都是存在的且有效的,这是为何呢?原来需要再web.config文件中添价少许配置代码就搞定. ...

  3. nginx单机1w并发设置

    关闭keep-live,提高链接回收 keeplive_timeout 0; events{ worker_connections 1024; } more /proc/sys/net/core/so ...

  4. [跨域]js设置document.domain实现跨域

    document.domain用来得到当前网页的域名.比如在地址栏里输入: 代码如下: javascript:alert(document.domain); //www.jb51.net 我们也可以给 ...

  5. javascript跨域的几种方法

    以下的例子包含的文件均为为 http://www.a.com/a.html .http://www.a.com/c.html 与 http://www.b.com/b.html,要做的都是从a.htm ...

  6. vue-cli脚手架安装过程(精简版)

    1:打开node的控制台,并找到对应的文件夹 2:检查node的版本 node -v 3:检查npm的版本 npm -v 4:检查cnpm的版本 cnpm -v 5:安装全局及脚手架 cnpm ins ...

  7. JS排序之选择排序

    遍历这个数组,先确定索引为0的数字为暂时最小数, 在剩下的数据中,以第一个为标杆,和剩下的数依次进行比较,如果标杆大于某数,则进行索引交换,继续比较,则a[i]=min; 最后让a[i]与索引为0的数 ...

  8. 联想VIBE Shot(Z90-7/全网通) 解锁BootLoader

    工具下载链接: http://pan.baidu.com/s/1dF7zGTb 备用下载链接: http://pan.baidu.com/s/1i4UHP4L 本篇教程教你如何傻瓜式解锁BootLoa ...

  9. AI:AI是什么?

    古老的哲学对科学有永远的借鉴意义,科学上的咬文嚼字往往会让其丧失完备性. 一.AI是什么 你看起来它有多好,它就有多好.本质只能通过表象来描述,在色即是空的逻辑里,图灵测试也许是最精准的AI测试方式. ...

  10. Java:Java 队列的遍历

    Java队列到底有没有可以遍历的功能呢?暂且试一下吧 参考链接:stl容器遍历测试 1.LinkedList实现简单遍历 for(Iter =LocTimesSerials.size()-1; iSe ...