|
||
|
|
|
Avaliação:
![]() ![]() ![]() ![]() | Publicado em: 23/05/2007Modelagem de Dados: Hierarquias - Parte 4
Gustavo Maia Aguiar é administrador de Empresas pela Universidade de Brasília (UnB) e pós-graduado em bancos de dados pela Universidade Católica de Brasília (UCB), atua na área de tecnologia de informação desde 2001, exercendo funções de desenvolvedor, analista, administrador de banco de dados (DBA) e administrador de dados (AD). É profissional certificado (MOS, MCDBA, MCAD, MCTS (SQL 2005), MCITP (DB Dev), MCITP (DB Admin), MCT e Itil Certified Professional) e suas áreas de interesse incluem .NET, XML, SQL Server, banco de dados em geral e Business Intelligence. É membro ativo dos fóruns MSDN e TechNet além de moderador da comunidade SQL Server Brasil (Orkut).
A técnica de Joe CelkoApós a seqüência de três artigos descrevendo o que são hierarquias, seus tipos e elementos, etc foram demonstradas algumas técnicas de representação como a técnica do modelo adjacente, a técnica dos caminhos materializados e a técnica da tabela ponte. As técnicas apresentadas possuem diversos pontos fortes e fracos. Essas técnicas lidam de formas diferentes com a navegação, com consultas de superior imediato, com a economia de espaço, atualização de registros, complexidade, etc. Algumas apresentam eficiência em alguns desses aspectos enquanto podem se mostrar insatisfatórias em outros. A utilização de extensões proprietárias pode ajudar a contornar as limitações, mas nem sempre as limitações são totalmente superadas. Será apresentada mais uma técnica que representa uma alternativa na representação de hierarquias nos modelos de dados no nível físico. Nesse artigo, será discorrida a explicação e a implementação da técnica de Joe Celko para forma de lidar com as hierarquias. Será utilizada ainda sua aplicação no exemplo da fictícia empresa ARP Associados. A origem Em algumas comunidades e fóruns que já participei, sempre que surgia um problema que envolvesse hierarquias, eram apontadas basicamente duas soluções. A primeira é o já descrito modelo adjacente e a segunda era o modelo dos caminhos aninhados que consiste em uma representação de autoria de Joe Celko (embora esse nome não seja citado na maioria das vezes). Entre outras atribuições, Joe Celko atua como um consultor independente e especialista em SQL e que reconhecendo as limitações da SQL para retornar determinadas combinações de dados que envolvam hierarquias, desenvolveu um modelo alternativo para modelar essas relações de tal forma que responder a determinadas perguntas resulta em uma instrução SQL mais performática e mais simples. A técnica de Joe Celko utiliza conceitos de glóbulos e extremidades. Para representar relações hierárquicas, cada nó “engloba” os seus nós inferiores. Esse processo inicia-se no nó raiz e vai até os nós folha. Antes de propriamente partir para a implementação, a figura abaixo mostra o organograma da ARP Associados e a relação entre os níveis através dos glóbulos:
Os níveis maiores englobam os níveis menores desde o nó raiz até os nós folha. Pode-se visualizar que o retângulo azul escuro, que representa o centro de custo “Presidência” engloba todos os demais centros de custos e que de forma semelhante o centro de custo “Finanças e Contabilidade” engloba os centros de custo “Orçamento” e “Execução”. Este artigo é a parte 4 de 4 da seguinte série:
luiz humberto de faria <lh_faria@hotmail.com>
parabens pelo artigo
![]() ![]() ![]() ![]() ![]() ![]() |
|
|