oracle:如何用sql生成日历
时间:2022-04-23
本文章向大家介绍oracle:如何用sql生成日历,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
BI分析中,经常需要将事实表与时间维度表关联起来,按年/月/日来逐层展示,常用的做法是创建一张日历表,结构类似如下:
create table T_BAS_CALENDAR
(
d_year NUMBER(4) not null,
d_month NUMBER(2) not null,
d_day NUMBER(2) not null
);
comment on table T_BAS_CALENDAR
is '日历表';
comment on column T_BAS_CALENDAR.d_year
is '年';
comment on column T_BAS_CALENDAR.d_month
is '月';
comment on column T_BAS_CALENDAR.d_day
is '日';
alter table T_BAS_CALENDAR
add constraint PK_BAS_CALENDAR primary key (D_YEAR, D_MONTH, D_DAY);
但是如何向这张表批量插入日历数据,方法就很多了,下面是仅用SQL语言生成日历的参考方法:
1 create or replace procedure P_IMPORT_CALENDAR(p_year_start number,
2 p_year_end number) is
3 cmonth integer;
4 cyear integer;
5 cday integer;
6 day_first integer;
7 day_last integer;
8 begin
9 --生成从p_year_start到p_year_end的所有日历 created by yjmyzz@126.com 2015-04-27
10
11 --firstly,delete history records
12 delete from T_BAS_CALENDAR where d_year between p_year_start and p_year_end;
13 for cyear in p_year_start .. p_year_end loop
14 for cmonth in 1 .. 12 loop
15 --get first-day of Month
16 select to_number(cyear || lpad(cmonth, 2, '0') || '01', '99999999')
17 into day_first
18 from dual;
19 --last-day of Month
20 select to_number(to_char(add_months(to_date(day_first, 'yyyyMMdd'), 1) - 1,
21 'yyyyMMdd'),
22 '99999999')
23 into day_last
24 from dual;
25 for cday in day_first .. day_last loop
26 --insert to table
27 INSERT INTO T_BAS_CALENDAR
28 (D_YEAR, D_MONTH, D_DAY)
29 VALUES
30 (CYEAR, CMONTH, SUBSTR(cday, 7));
31 end loop;
32 end loop;
33 end loop;
34 commit;
35 end P_IMPORT_CALENDAR;

- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- python 迭代器/iterator与生成器/generator的区别
- CSS 实现文本超出容器范围用省略号显示(单行+多行)
- ESP8266和ROS收发消息读取模拟量控制LED亮度
- 纯 CSS 实现下拉菜单尖角图标(实心+空心)
- 3分钟短文:书接上回,Laravel数据库迁移的那些个小技巧
- 解密 Docker 挂载文件,宿主机修改后容器里文件没有修改
- SAP Spartacus的单元测试目录结构
- 突击并发编程JUC系列-并发工具 CyclicBarrier
- 详解 | Linux系统是如何实现存储并读写文件的?
- Angular单元测试的一个错误消息
- Python进行特征提取
- dotnet OpenXML 元素 cNvPr NonVisual Drawing Properties 的属性作用
- Java 对象相关面试题
- 【每日一题】【vue2源码学习】VUE中模版编译原理
- 【每日一题】【vue2源码学习】对VUE响应式数据的理解