recherche
Maisonbase de donnéestutoriel mysqlComment créer des relations entre les tables MySQL en utilisant des contraintes de clés étrangères?

How to Create Relationships Between MySQL Tables Using FOREIGN KEY Constraints?

Maîtriser les relations MySQL avec les contraintes FOREIGN KEY

MySQL, l'un des principaux systèmes de gestion de bases de données relationnelles (SGBDR), s'appuie fortement sur l'établissement de relations entre les tables pour une gestion efficace des données. Cet article se concentre sur la création de relations, en reliant spécifiquement les tables accounts et customers, en attribuant chaque compte à un client unique.

La pierre angulaire de ce processus est la contrainte FOREIGN KEY. Illustrons comment implémenter cela dans MySQL :

CREATE TABLE accounts (
    account_id INT NOT NULL AUTO_INCREMENT,
    customer_id INT(4) NOT NULL,
    account_type ENUM('savings', 'credit') NOT NULL,
    balance FLOAT(9) NOT NULL,
    PRIMARY KEY (account_id),
    FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
) ENGINE=INNODB;

La ligne clé, FOREIGN KEY (customer_id) REFERENCES customers(customer_id), définit la relation. Il stipule que le customer_id dans le tableau accounts doit correspondre à un customer_id valide dans le tableau customers.

Cette contrainte maintient l'intégrité référentielle, garantissant l'exactitude et la cohérence des données. Il empêche la création d'enregistrements « orphelins » (comptes sans clients correspondants) et maintient les relations entre les données.

Considération importante : Le moteur MyISAM de MySQL ne prend pas en charge FOREIGN KEY. Pour les tables MyISAM, des méthodes alternatives telles que les déclencheurs sont nécessaires pour imiter la fonctionnalité FOREIGN KEY.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Comment MySQL gère-t-il la concurrence par rapport aux autres SGBDR?Comment MySQL gère-t-il la concurrence par rapport aux autres SGBDR?Apr 29, 2025 am 12:44 AM

Mysqlhandlesconcurrencyusingamixofrow-leveLandTable-levellocking, principalement throughinnodb'srow-levellocking.comparedtootherrdbm

Comment MySQL gère-t-il les transactions par rapport aux autres bases de données relationnelles?Comment MySQL gère-t-il les transactions par rapport aux autres bases de données relationnelles?Apr 29, 2025 am 12:37 AM

Mysqlhandlestransactionseffectively usingtheinNodBengine, soutenant lespropertisimilartopostgresqlandoracle.1) MySqlusesRepeatableReadSthedefaultisolationLevel

Quels sont les types de données disponibles dans MySQL?Quels sont les types de données disponibles dans MySQL?Apr 29, 2025 am 12:28 AM

Les types de données MySQL sont divisés en types numériques, date et heure, chaîne, binaires et spatiaux. La sélection du type correct peut optimiser les performances de la base de données et le stockage de données.

Quelles sont les meilleures pratiques pour écrire des requêtes SQL efficaces dans MySQL?Quelles sont les meilleures pratiques pour écrire des requêtes SQL efficaces dans MySQL?Apr 29, 2025 am 12:24 AM

Les meilleures pratiques incluent: 1) Comprendre la structure des données et les méthodes de traitement MySQL, 2) Indexation appropriée, 3) Évitez de sélectionner *, 4) en utilisant les types de jointure appropriés, 5) Utilisez des sous-requêtes avec prudence, 6) Analyser les requêtes avec Explication, 7) Considérez l'impact des requêtes sur les ressources du serveur, 8) Maintenir la base de données régulièrement. Ces pratiques peuvent faire des requêtes MySQL non seulement rapidement, mais aussi la maintenabilité, l'évolutivité et l'efficacité des ressources.

En quoi MySQL diffère-t-il de PostgreSQL?En quoi MySQL diffère-t-il de PostgreSQL?Apr 29, 2025 am 12:23 AM

MysqlisbetterforspeedandsImplicité, adapté aux webapplications; postgresqlexcelsincomplexdatascenarioswithrobustfeatures.mysqlisidealforquickprojectsAndread-havevytasks, tandis que

Comment MySQL gère-t-il la réplication des données?Comment MySQL gère-t-il la réplication des données?Apr 28, 2025 am 12:25 AM

MySQL traite la réplication des données à travers trois modes: réplication asynchrone, semi-synchrone et de groupe. 1) Les performances de réplication asynchrones sont élevées mais les données peuvent être perdues. 2) La réplication semi-synchrone améliore la sécurité des données mais augmente la latence. 3) La réplication du groupe prend en charge la réplication et le basculement multi-maître, adaptés aux exigences de haute disponibilité.

Comment pouvez-vous utiliser l'instruction Explication pour analyser les performances de la requête?Comment pouvez-vous utiliser l'instruction Explication pour analyser les performances de la requête?Apr 28, 2025 am 12:24 AM

L'instruction Explication peut être utilisée pour analyser et améliorer les performances de la requête SQL. 1. Exécutez la déclaration Expliquez pour afficher le plan de requête. 2. Analyser les résultats de sortie, prêter attention au type d'accès, à l'utilisation d'index et à la commande de jointure. 3. Créer ou ajuster les index en fonction des résultats de l'analyse, optimiser les opérations de jointure et éviter la numérisation complète de la table pour améliorer l'efficacité de la requête.

Comment sauvegardez-vous et restaurez-vous une base de données MySQL?Comment sauvegardez-vous et restaurez-vous une base de données MySQL?Apr 28, 2025 am 12:23 AM

L'utilisation de MySQLDump pour la sauvegarde logique et MySQLenterPriseBackup pour la sauvegarde à chaud sont des moyens efficaces de sauvegarder les bases de données MySQL. 1. Utilisez MySQLDump pour sauvegarder la base de données: mysqldump-uot-pmydatabase> mydatabase_backup.sql. 2. Utilisez MySQLenterPriseBackup pour Hot Backup: MySqlBackup - User = root-patkword = mot de passe - Backup-Dir = / path / to / backupbackup. Lorsque vous récupérez, utilisez la vie correspondante

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel