首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLPlus中的时间维表

SQLPlus中的时间维表
EN

Stack Overflow用户
提问于 2020-05-23 14:30:34
回答 1查看 81关注 0票数 0

我正在用Oracle (SQLPlus)为大学做一个数据仓库项目。我需要创建时间维度表并填充它。桌子应该是这样的:

它需要从2004年到2019年。

我尝试过不同的东西和查询,但它们不起作用,遗憾的是,我对SQLPlus还不太了解,无法自己创建一个(或者成功地修改一个)。我完全迷路了。

非常感谢您的帮助和耐心。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-23 15:13:54

代码语言:javascript
复制
create table date_dim
(id number(38),
date date,
id_dayofweek number(38),
dayofweek varchar(100),
id_holiday number(38),
 id_month number(38),
 month varchar(100),  
 id_year number(38),
 id_total number(38),
 Total varchar(100));

使用上面的查询创建表。

对于数据,可以通过connect by子句生成数据。

代码语言:javascript
复制
insert into date_dim
(select level as id, to_date('31-DEC-2003', 'DD-MON-YYYY') + level as date1,   
case when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Monday' then 2
when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Tuesday' then 3
when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Wednesday' then 4
when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Thursday' then 5
when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Friday' then 6
when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Saturday' then 7
when ltrim(rtrim(to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day'))) = 'Sunday' then 1 end as id_dayofweek,
to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Day') as dayofweek,
0 as id_holiday,
to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'MM') as id_month,
to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'Month') as month,
to_char(to_date('31-DEC-2003', 'DD-MON-YYYY') + level, 'YYYY') as year,
1 as id_total,
'Total' as Total
from dual
connect by level < = 5844);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61973550

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档