Técnicas de Normalização
Segunda Forma Normal
Nós extraímos os valores url para uma tabela separada para que possamos adicionar mais urls no futuro sem ter que duplicar os dados. Nós também vamos querer usar nosso valor de chave primária para relacionar estes campos:
<table align="center" border="1" cellpadding="4" cellspacing="0" width="400" bgcolor="#FFFFFF" bordercolor="#CCCCCC" style="font-family: arial; font-size: 10pt;"><tr align="center"><td colspan="4" bgcolor="#DDDDDD">usuarios</td></tr><tr align="center"><td bgcolor="#FFCC00">usrId</td><td>nome</td><td>empresa</td><td>empresa_endereco</td></tr><tr align="center"><td>1</td><td>Carlos</td><td>ABC</td><td>Santos Dummont, 100</td></tr><tr align="center"><td>2</td><td>Flávia</td><td>XYZ</td><td>Des. Moreira, 100</td></tr></table>
<table align="center" border="1" cellpadding="4" cellspacing="0" width="400" bgcolor="#FFFFFF" bordercolor="#CCCCCC" style="font-family: arial; font-size: 10pt;"><tr align="center"><td colspan="3" bgcolor="#DDDDDD">urls</td></tr><tr align="center"><td>urlId</td><td bgcolor="#FFCC00">relusrId</td><td>url</td></tr><tr align="center"><td>1</td> <td>1</td><td>abc.com</td></tr><tr align="center"><td>2</td><td>1</td><td>xyz.com</td></tr><tr align="center"><td>3</td><td>2</td><td>abc.com</td></tr><tr align="center"><td>4</td><td>2</td><td>xyz.com</td></tr></table>
Ok, nós criamos tabelas separadas e a chave primária na tabela de usuários, usrId, agora está relacionada à chave estrangeira na tabela de urls, relusrId. Nós temos uma forma muito melhor agora. Mas o que acontece se quisermos adicionar outro empregado da companhia ABC ? Ou 200 empregados ? Teríamos agora nomes de companhias e de empregados duplicando-se por todos os lugares, uma situação perfeita para duplicar erros em nossos dados. Então teremos que aplicar a Terceira Forma Normal:
- Criar tabelas separadas para conjuntos de valores que se aplicam a registros múltiplos
- Relacionar estas tabelas com chaves estrangeiras
Nós extraímos os valores url para uma tabela separada para que possamos adicionar mais urls no futuro sem ter que duplicar os dados. Nós também vamos querer usar nosso valor de chave primária para relacionar estes campos:
<table align="center" border="1" cellpadding="4" cellspacing="0" width="400" bgcolor="#FFFFFF" bordercolor="#CCCCCC" style="font-family: arial; font-size: 10pt;"><tr align="center"><td colspan="4" bgcolor="#DDDDDD">usuarios</td></tr><tr align="center"><td bgcolor="#FFCC00">usrId</td><td>nome</td><td>empresa</td><td>empresa_endereco</td></tr><tr align="center"><td>1</td><td>Carlos</td><td>ABC</td><td>Santos Dummont, 100</td></tr><tr align="center"><td>2</td><td>Flávia</td><td>XYZ</td><td>Des. Moreira, 100</td></tr></table>
<table align="center" border="1" cellpadding="4" cellspacing="0" width="400" bgcolor="#FFFFFF" bordercolor="#CCCCCC" style="font-family: arial; font-size: 10pt;"><tr align="center"><td colspan="3" bgcolor="#DDDDDD">urls</td></tr><tr align="center"><td>urlId</td><td bgcolor="#FFCC00">relusrId</td><td>url</td></tr><tr align="center"><td>1</td> <td>1</td><td>abc.com</td></tr><tr align="center"><td>2</td><td>1</td><td>xyz.com</td></tr><tr align="center"><td>3</td><td>2</td><td>abc.com</td></tr><tr align="center"><td>4</td><td>2</td><td>xyz.com</td></tr></table>
Ok, nós criamos tabelas separadas e a chave primária na tabela de usuários, usrId, agora está relacionada à chave estrangeira na tabela de urls, relusrId. Nós temos uma forma muito melhor agora. Mas o que acontece se quisermos adicionar outro empregado da companhia ABC ? Ou 200 empregados ? Teríamos agora nomes de companhias e de empregados duplicando-se por todos os lugares, uma situação perfeita para duplicar erros em nossos dados. Então teremos que aplicar a Terceira Forma Normal:
estava testando aki, eu programo php com mysql no windows e qundo ta ok testo no linux, tive um problema de campos no mysql, onde os num posso usar maiusculas no nomes dos campos, tem que se rtudo minusculo....alguem ja passou por isso?
25/10/2004 1:46pm
(~20 anos atrás)
isso foi o que eu não entendi, você quis dizer que se eu pegar as chaves estrangeiras de outras tabelas eu consigo reconstituir essa tabela de quinta forma ? :)
17/04/2002 11:36am
(~22 anos atrás)
Opa André, acho que me enganei aqui nos emails, me desculpe.
Bem, quanto a quinta forma como não é algo muito utilizado o autor se restringiu a apenas comentá-la. Na verdade você faz a volta do que você fez, vai destrinchando as tabelas inferiores até chegar a uma tabela principal, na verdade é apenas ler o artigo de trás pra frente. É mais uma forma de se certificar que uma tabela está restringida ao máximo do que uma forma de construir a tabela principal.
[]s
Bem, quanto a quinta forma como não é algo muito utilizado o autor se restringiu a apenas comentá-la. Na verdade você faz a volta do que você fez, vai destrinchando as tabelas inferiores até chegar a uma tabela principal, na verdade é apenas ler o artigo de trás pra frente. É mais uma forma de se certificar que uma tabela está restringida ao máximo do que uma forma de construir a tabela principal.
[]s
17/04/2002 11:28am
(~22 anos atrás)
Olá André...
...quando você vai começar a estruturar um banco de dados com tabelas e etc, você começa estabelecendo uma tabela no Formato Zero, como é mostrado no artigo. Você nunca começa com as tabelas já normalizadas, a não ser que você tenha uma boa experiência já e comece já fazendo uma normalização inicial.
Então, a princípio você estabelece uma tabela na Forma Zero e vai aplicando regras de normalização.
[]s
...quando você vai começar a estruturar um banco de dados com tabelas e etc, você começa estabelecendo uma tabela no Formato Zero, como é mostrado no artigo. Você nunca começa com as tabelas já normalizadas, a não ser que você tenha uma boa experiência já e comece já fazendo uma normalização inicial.
Então, a princípio você estabelece uma tabela na Forma Zero e vai aplicando regras de normalização.
[]s
17/04/2002 11:17am
(~22 anos atrás)
Acho que a Quinta forma ficou muito no "ar", seria interessante se você conseguisse exemplificar, como nas outras formas ! :-)
15/04/2002 10:42am
(~22 anos atrás)