Maison >base de données >tutoriel mysql >Comment puis-je gérer les valeurs nullables dans les contraintes de clé étrangère MySQL ?

Comment puis-je gérer les valeurs nullables dans les contraintes de clé étrangère MySQL ?

DDD
DDDoriginal
2024-10-30 10:15:02201parcourir

 How Can I Handle Nullable Values in MySQL Foreign Key Constraints?

Clés étrangères MySQL : gestion des valeurs nullables

Vous avez conçu un schéma pour représenter les images et leurs indicateurs associés. Le type de résolution d'indicateur est initialement nullable, mais doit appliquer une contrainte de clé étrangère une fois qu'une valeur est définie.

Dans MySQL, vous pouvez configurer une colonne de clé étrangère pour autoriser NULL. Ceci est réalisé en supprimant la contrainte NOT NULL de la définition de colonne. En autorisant NULL, vous permettez à la colonne d'accepter à la fois les ID de type de résolution valides et les valeurs NULL.

Voici le schéma modifié :

CREATE TABLE tblImageFlags (
    imageFlagID INT UNSIGNED NOT NULL AUTO_INCREMENT,
    imageID INT UNSIGNED NOT NULL,
    flagTypeID INT UNSIGNED NOT NULL,
    resolutionTypeID INT UNSIGNED,  -- Removed NOT NULL constraint
    ...
);

Maintenant, vous pouvez insérer des lignes dans tblImageFlags avec une résolution NULL genres. Lorsqu'une résolution est déterminée ultérieurement, vous pouvez mettre à jour la colonne avec l'ID du type de résolution correspondant.

Clarification sur les "Index" et "Indices"

Dans le contexte de bases de données, le pluriel de « index » est « index » et non « index ». C’est la forme plurielle préférée pour un usage quotidien. Bien que les « indices » soient parfois rencontrés dans des contextes techniques, leur utilisation est considérée comme prétentieuse et moins courante que les « index ».

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