Eu tenho uma tabela de fatos de snapshot acumulativa que rastreia a entrada e saída de contêineres em um terminal .
Os contêineres podem entrar e sair de três maneiras diferentes , então pensei em criar uma tabela de dimensões específica que lista essas três maneiras possíveis ( trem, embarcação ou caminhão ).
Então li este artigo, que basicamente diz que essa técnica está errada, mas não consigo entender o porquê.
Primeiro artigo:
Às vezes, quando uma tabela de fatos tem uma lista longa de fatos que são escassamente preenchidos em qualquer linha individual, é tentador criar uma dimensão do tipo de medida que reduz a linha da tabela de fatos para um único fato genérico identificado pela dimensão do tipo de medida. Geralmente, não recomendamos essa abordagem. Embora remova todas as colunas de fatos vazias, multiplica o tamanho da tabela de fatos pelo número médio de colunas ocupadas em cada linha e dificulta muito os cálculos entre colunas. Essa técnica é aceitável quando o número de fatos em potencial é extremo (centenas), mas menos de um punhado seria aplicável a qualquer linha da tabela de fatos.
Entendo que, se uma " Dimensão do tipo de medida " for implementada para uma tabela de fatos de transação, ela poderá criar problemas como este outro artigo diz, mas não vejo nenhuma desvantagem se usada para um fato de instantâneo acumulado .
Segundo artigo: (algumas desvantagens da implementação de uma "Dimensão do tipo de medida")
- [...] Se escolhermos uma "Dimensão do tipo de medida", perderemos essa capacidade analítica. Se uma medida não for compatível com as outras, não podemos adicioná-las.
- [...] Quanto mais número de passes nosso SQL precisar executar para produzir um relatório, mais lento será o relatório.
- [...] Na ferramenta de BI, se você não colocar o filtro do tipo de medida, você está arriscando o usuário a obter "informações de lixo". Do ponto de vista da usabilidade, esse design é um lixo.
Resposta à resposta de Mark Storey-Smith
Abordagem muito agradável, eu nunca teria pensado nisso.
Outra coisa: toda entrada e saída de um veículo que leva contêiner para o terminal tem um ID único, que me fornece outras informações como: chegada prevista do veículo, chegada real, se for uma embarcação no cais, se for um caminhão no pedágio e muitas outras informações ...
Essas são três tabelas de fatos diferentes e devem estar vinculadas de alguma forma à tabela de fatos do contêiner.
Eu pensei que o ID da viagem fosse um degenerate dimension
, então ele entraria diretamente na tabela de fatos do contêiner. Então, a minha dúvida é: devo adicionar 6 campos diferentes na tabela de fatos do contêiner (embarcação_voyage_in_key, embarcação_voyage_out_key, trem_voyage_in_key, trem_voyage_out_key, truck_voyage_in_key, truck_voyage_out_key) ou apenas 2 outros campos (viagem_in, viagem_várias)
Espero que minha dúvida esteja clara, obrigado.