Select the product you need help with
Principes de base de la normalisation des bases de donnéesNuméro d'article: 283878 - Voir les produits auxquels s'applique cet article Ancien nº de publication de cet article : F283878 Utilisateur débutant : requiert la connaissance de l'interface utilisateur sur les ordinateurs mono-utilisateur. Pour vous procurer une version Microsoft Access 2000 de cet article, reportez-vous à l'article 209534
(http://support.microsoft.com/kb/209534/
)
. Pour vous procurer une version Microsoft Access 95 ou Microsoft Access 97 de cet article, reportez-vous à l'article 100139
(http://support.microsoft.com/kb/100139/
)
. SommaireRésumé Cet article explique la terminologie de normalisation des bases de données pour les utilisateurs débutants. Une connaissance élémentaire de cette terminologie est utile lors de la discussion de la structure d'une base de données relationnelle. REMARQUE : Microsoft propose également une présentation technique en ligne abordant les principes de base de la normalisation des bases de données. Pour afficher cette présentation technique en ligne, reportez-vous au site Web de Microsoft à l'adresse suivante (en anglais) : http://support.microsoft.com/servicedesks/webcasts/wc060600/wc060600.asp?fr=1
(http://support.microsoft.com/?scid=http%3a%2f%2fsupport.microsoft.com%2fservicedesks%2fwebcasts%2fwc060600%2fwc060600.asp%3ffr%3d1)
Plus d'informationsDescription de la normalisationLa normalisation correspond au processus d'organisation des données dans une base de données. Ce processus comprend la création de tables et l'établissement de relations entre celles-ci conformément à des règles conçues à la fois pour protéger les données et pour rendre la base de données plus flexible grâce à l'élimination de la redondance et des dépendances incohérentes.Les données redondantes entraînent un gaspillage d'espace disque et créent des problèmes de maintenance. Lorsque des données existant en plusieurs endroits doivent être modifiées, elles doivent l'être exactement de la même façon dans tous ces emplacements. Une modification d'adresse de client est beaucoup plus facile à implémenter lorsque ces données sont stockées dans la table Clients et nulle part ailleurs dans la base de données. Qu'est-ce qu'une « dépendance incohérente » ? Bien qu'il puisse être intuitif pour un utilisateur de rechercher dans la table Clients l'adresse d'un client donné, il ne serait pas très logique d'y rechercher le salaire de l'employé chargé du dossier de ce client. Le salaire de l'employé est lié à (ou dépend de) l'employé et doit par conséquent être déplacé dans la table Employés. Les dépendances incohérentes peuvent rendre l'accès aux données plus difficile car le chemin d'accès à ces données peut être manquant ou rompu. Il existe plusieurs règles de normalisation des bases de données. Ces règles sont connues sous le nom de « formes normales ». Si la première règle est respectée, la base de données sera considérée comme étant en « première forme normale ». Si les trois premières règles sont respectées, la base de données sera considérée comme étant en « troisième forme normale ». Bien que d'autres niveaux de normalisation soient possibles, la troisième forme normale est considérée comme étant le niveau le plus élevé nécessaire à la plupart des applications. Comme c'est le cas avec de nombreuses règles et spécifications formelles, les scénarios du monde réel n'autorisent pas toujours une conformité parfaite. En général, la normalisation exige des tables supplémentaires, ce qui peut être incommode aux yeux de certains clients. Si vous décidez d'enfreindre une des trois premières règles de normalisation, assurez-vous que votre application anticipe les problèmes pouvant survenir, tels que la présence de données redondantes ou de dépendances incohérentes. Les descriptions suivantes incluent des exemples. Première forme normale
Que se passe-t-il lorsque vous ajoutez un troisième fournisseur ? Ajouter un champ ne constitue pas la bonne solution. Cela exige des modifications de programme et de table et ne convient pas parfaitement à une quantité dynamique de fournisseurs. Au lieu de cela, vous devez placer toutes les informations relatives aux fournisseurs dans une table distincte nommée Fournisseurs, puis lier le stock aux fournisseurs à l'aide d'une clé de numéro d'article ou lier les fournisseurs au stock à l'aide d'une clé de code de fournisseur. Deuxième forme normale
Troisième forme normale
Par exemple, dans une table Recrutement des employés, le nom et l'adresse de l'université d'un candidat peuvent être inclus. Mais vous devez posséder une liste complète des universités pour le publipostage. Si les informations relatives aux universités sont stockées dans la table Candidats, il n'y a aucun moyen de dresser la liste des universités ne possédant pas de candidat actuellement. Créez une table Universités distincte et liez-la à la table Candidats avec une clé de code d'université. EXCEPTION : le respect de la troisième forme normale, bien que théoriquement souhaitable, n'est pas toujours réalisable. Si vous possédez une table Clients et souhaitez éliminer toutes les dépendances interchamps possibles, vous devez créer des tables distinctes pour les villes, les codes postaux, les représentants de commerce, les classes de clientèle et tout autre facteur pouvant être dupliqué dans plusieurs enregistrements. En théorie, la normalisation est un objectif louable. Toutefois, la présence de nombreuses petites tables peut amoindrir les performances ou excéder les capacités mémoire ou de fichiers ouverts. Il sera sans doute plus faisable d'appliquer la troisième forme normale uniquement aux données qui changent fréquemment. S'il reste des champs dépendants, concevez votre application de sorte que l'utilisateur doive vérifier tous les champs connexes lorsque l'un d'entre eux est modifié. Autres formes de normalisationIl existe une quatrième forme normale, également nommée Boyce Codd Normal Form (BCNF) et une cinquième forme normale, mais elles sont rarement prises en compte en pratique. Le non-respect de ces règles peut engendrer une structure de base de données moins que parfaite, mais la fonctionnalité de la base de données ne devrait pas en souffrir.Normalisation d'un exemple de tableLes étapes suivantes démontrent le processus de normalisation d'une table d'étudiants fictive.
PropriétésNuméro d'article: 283878 - Dernière mise à jour: vendredi 23 février 2007 - Version: 6.2 Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT. | Traductions disponibles
|


Retour au début








