Postgres:根据 Ralph Kimball 创建日期维度

发布于 2024-11-29 21:03:20 字数 240 浏览 1 评论 0原文

我是 postgres 和 DW 的新手,我必须设计 。我在网上看到了很多地方,到目前为止我还没有成功,可以解释一下如何填充诸如“财政周”,“财政月”,“财政半年”之类的字段

谢谢

I am new to postgres and DW, and I have to design a DATE Dimension as given in book. I saw many places on the web and I did not succeed so far, can some explain how to populate fields like 'Fiscal Week', 'Fiscal Month', 'Fiscal Half year'

Thank you

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

拒绝两难 2024-12-06 21:03:20

我猜您需要 10 年日期维度表,其中包含图 2.4 中显示的所有列(基于 Google 图书)。查看文档:

要获取 10 年内的所有日期,您可以编写:

SELECT generate_series('2001-01-01'::date, '2010-12-31'::date, '1 day') AS day;

SELECT count(*) FROM generate_series('2001-01-01'::date, '2010-12-31'::date, '1 day');
 count 
-------
  3652
(1 row)

根据图 2.5 创建表,例如:

DROP TABLE IF EXISTS "Date Dimension";
CREATE TABLE "Date Dimension"
(
    "Date Key" serial,
    "Date" date,
    "Full Day Description" text,
    "Day Of Week" text,
    "Calendar Month" text,
    "Calendar Year" integer,
    "Fiscal Year Month" text,
    "Holiday Indicator" text,
    "Weekday Indicator" text 
);

插入命令:

INSERT INTO "Date Dimension"
    ("Date", "Full Day Description", "Day Of Week", "Calendar Month",
    "Calendar Year", "Fiscal Year Month", "Holiday Indicator",
    "Weekday Indicator")
SELECT
    day,
    rtrim(to_char(day, 'Month')) || to_char(day, ' DD, YYYY'),
    to_char(day, 'Day'),
    rtrim(to_char(day, 'Month')),
    date_part('year', day),
    'F' || to_char(day, 'YYYY-MM'),
    '', --omitting (trivial 'Holiday'/'Non-Holiday, but how to get this ??),
    CASE
        WHEN date_part('isodow', day) IN (6, 7) THEN 'Weekend'
        ELSE 'Weekday'
    END
FROM
    generate_series('2001-01-01'::date, '2010-12-31'::date, '1 day') day;

I希望这能为您提供一些框架和起点。

I guess that you want 10 years Date Dimension table with all columns presented in Figure 2.4 (based on Google Books). Check in documentation:

To get all days within 10 years you could write:

SELECT generate_series('2001-01-01'::date, '2010-12-31'::date, '1 day') AS day;

SELECT count(*) FROM generate_series('2001-01-01'::date, '2010-12-31'::date, '1 day');
 count 
-------
  3652
(1 row)

According to Figure 2.5 create table as e.g.:

DROP TABLE IF EXISTS "Date Dimension";
CREATE TABLE "Date Dimension"
(
    "Date Key" serial,
    "Date" date,
    "Full Day Description" text,
    "Day Of Week" text,
    "Calendar Month" text,
    "Calendar Year" integer,
    "Fiscal Year Month" text,
    "Holiday Indicator" text,
    "Weekday Indicator" text 
);

Insert command:

INSERT INTO "Date Dimension"
    ("Date", "Full Day Description", "Day Of Week", "Calendar Month",
    "Calendar Year", "Fiscal Year Month", "Holiday Indicator",
    "Weekday Indicator")
SELECT
    day,
    rtrim(to_char(day, 'Month')) || to_char(day, ' DD, YYYY'),
    to_char(day, 'Day'),
    rtrim(to_char(day, 'Month')),
    date_part('year', day),
    'F' || to_char(day, 'YYYY-MM'),
    '', --omitting (trivial 'Holiday'/'Non-Holiday, but how to get this ??),
    CASE
        WHEN date_part('isodow', day) IN (6, 7) THEN 'Weekend'
        ELSE 'Weekday'
    END
FROM
    generate_series('2001-01-01'::date, '2010-12-31'::date, '1 day') day;

I hope this gives you some framework and starting point.

白芷 2024-12-06 21:03:20

您的财政年度是如何构成的?什么时候开始?它是否遵循任何标准 4-4-5 或 4-5-4 规则?您最好的选择可能是从 CSV 文件加载它,如此问题的答案中所述:4-5-4 国家零售基金会日历 csv 下载或创建函数。众所周知,财政年度是不标准的。例如,我们公司的会计年度从 7 月 1 日开始。

我必须向广播日历的日历维度添加字段(从包括 1 月 1 日在内的一周的星期一开始),并且能够通过一些计算来完成此操作。

How is your fiscal year structured? When does it start? Does it follow any standard 4-4-5 or 4-5-4 rules? Your best bet might be loading it from a CSV file such as discussed in the answer to this question: 4-5-4 National Retail foundation Calendar csv download or function to create. Fiscal years are notoriously non-standard. For example, the fiscal year of our company starts July 1st.

I had to add fields to our calendar dimension for the broadcast calendar (starts on the Monday of the week that includes January 1st) and was able to do it with some calculations.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文