在数据仓库的创建过程中,往往需要创建日期维度来为以后的数据分析来服务。
方面从多个日期角度:
如:年-月-日,年-季度-月-日,年-周-日
(1) 创建表的脚本如下
(存储过程的创建过程中有一步操作是向time_dimension表中插入数据,所以首先需要创建好此表)
create table TIME_DIMENSION ( the_date NUMBER not null, date_name NVARCHAR2(15), the_year NUMBER, year_name NVARCHAR2(10), the_quarter VARCHAR2(10), quarter_name NVARCHAR2(10), the_month NUMBER, month_name NVARCHAR2(10), the_week NUMBER, week_name NVARCHAR2(10), week_day NVARCHAR2(10) ) tablespace DEV1_ODI_USER pctfree 10 initrans 1 maxtrans 255 storage ( initial 64 next 1 minextents 1 maxextents unlimited );
(2) 存储过程脚本如下
create or replace PROCEDURE SP_CREATE_TIME_DIMENSION(begin_date in varchar2,end_date in varchar2) is dDate date; v_the_date number; v_the_year varchar2(4); v_the_quarter varchar2(2); v_the_month varchar2(10); v_the_month2 varchar2(2); v_the_week varchar2(2); v_the_day varchar2(10); v_the_day2 varchar2(2); v_week_day nvarchar2(10); adddays int; BEGIN adddays := 1 ; dDate := to_date(begin_date,'yyyymmdd'); WHILE (dDate <= to_date(end_date,'yyyymmdd')) loop v_the_date := to_number(to_char(dDate,'yyyymmdd'));--key值 v_the_year:= to_char(dDate, 'yyyy');--年 v_the_quarter := to_char(dDate, 'q');--季度 v_the_month:=to_char(dDate, 'mm');--月份(字符型) v_the_month2:=to_number(to_char(dDate, 'mm'));--月份(数字型) v_the_day:=to_char(dDate, 'dd');--日(字符型) v_the_day2:=to_char(dDate, 'dd'); v_the_week:= to_char(dDate,'fmww');--年的第几周 v_week_day := to_char(dDate, 'day'); --星期几 insert into time_dimension(the_date,date_name,the_year,year_name, the_quarter,quarter_name,the_month, month_name,the_week,week_name,week_day) values(v_the_date,v_the_year||'年'||v_the_month2||'月'||v_the_day2||'日',v_the_year,v_the_year||'年', v_the_year||'Q'||v_the_quarter,v_the_year||'年'||v_the_quarter||'季度',to_number(v_the_year||v_the_month), v_the_year||'年'||v_the_month2||'月',v_the_week,'第'||v_the_week||'周', v_week_day); dDate := dDate + adddays; END loop; end SP_CREATE_TIME_DIMENSION;
(3) 命令窗口的执行脚本如下
SQL> exec SP_CREATE_TIME_DIMENSION(20140101,20140630); PL/SQL procedure successfully completed SQL> commit; Commit complete SQL> select * from time_dimension;
相关推荐
python-oracledb的源码和使用示例代码, python-oracledb 1.0,适用于Python versions 3.6 through 3.10. Oracle Database; This directory contains samples for python-oracledb. 1. The schemas and SQL ...
针对网上一些创建时间维度的帖子的不完整,不可执行,特地整理了这个文件。RBAC_DIM_DAY.sql为日维度含数据,RBAC_DIM_MONTH为月维度含数据,RBAC_DIM_QUARTER为季维度含数据,RBAC_DIM_YEAR为年维度含数据和脚本...
oracledb_exporter.0.2.2.linux-amd64.tar.gz Oracledb_exporter导出器是模仿 MySQL 导出器
oracledb_exporter 是prometheus 的一个对Oracle监控的Exporter , Prometheus+Grafana 对Oracle实现监控
Oracle创建DBlink连接MYSQL数据库
Oracle DB优化总结
详细描述了在oracle中创建方案的3种方法,包括利用图形界面和sql语句
oracle 创建dblink的详细步骤,以及使用oracle快照快速的刷新,保持本地与远程数据库的同步
Node.js环境下利用node-oracledb操作oracle数据库,实现增删改查等操作。文件包括node项目、npm包依赖、node-oracledb示例。具体内容可参照博客https://blog.csdn.net/wml00000/article/details/106374969
Oracle_View视图创建在oracle数据库中已建立两张表rt_issuesect和roadstate,表结构如下: 高架状态表结构rt_issuesect
多维度查询时通常需要建立多个游标循环,查询效率无法得到保障,现在通过游标和substr()函数相结合的方式提高查询效率
Oracle安装光盘后安装数据库一路next,到了最后创建数据库的时候遇到了问题,进度停止不前, 解决办法 1.安装数据库的时候不要选择“创建数据库”选项,或者用高级安装,最后一步选择不创建数据库。 2.安装完成后...
oracle手动创建数据库
oracle数据库创建脚本 #!/bin/sh OLD_UMASK=`umask` umask 0027 mkdir -p /oradata mkdir -p /u01/app/oracle/admin/tdrb/adump mkdir -p /u01/app/oracle/admin/tdrb/dpdump mkdir -p /u01/app/oracle/admin/tdrb...
详解Oracle数据库的db_cache_size和granule_size 摘取了官方文档的描述,用中文进行了分析
oracle数据库导入、导出数据、创建表空间、创建用户、用户授权等操作
详解oracle用户创建(create user)(上) 转载 http://blog.itpub.net/26110315/viewspace-715882/ 用户能访问数据库前必须要有获得相应授权的账号,oracle中创建一个用户并为其分配密码很简单,但是在创建用户的同时...
创建学员信息表--创建唯一索引--修改学员信息表添加主键和检查约束
oracleJob创建job的脚本。 sql语句
Oracle应用项目——使用OracleEM创建表空间.pdf 学习资料 复习资料 教学资源