Comment utiliser la fonction coalesce () dans MySQL?
Coalesce () renvoie la première valeur non nul à partir d'une liste d'expressions, permettant une manipulation gracieuse des données manquantes en remplaçant les défauts de défaut, en fusionnant les valeurs de colonne, en soutenant les calculs avec des champs facultatifs et en fournissant des repères dans les jointures et des agrégations, en garantissant des résultats prévisibles lors de la gestion de Nulls dans MySQL.
La fonction COALESCE()
dans MySQL est utilisée pour renvoyer la première valeur non nulle d'une liste d'expressions. Il est particulièrement utile lors de la gestion des données manquantes ou facultatives, par exemple lors de l'adhésion aux tables ou de la gestion des valeurs par défaut.
Ce que fait de fusionner ()
COALESCE(value1, value2, ..., valueN)
évalue les arguments dans l'ordre et renvoie le premier qui n'est pas NULL
. Si toutes les valeurs sont NULL
, elle renvoie NULL
.
Cette fonction est utile dans des scénarios comme:
- Remplacement des valeurs
NULL
par des valeurs par défaut - Fusion des données de plusieurs colonnes
- Gestion des entrées utilisateur en option
Gérer les valeurs nuls avec les secours
L'une des utilisations les plus courantes consiste à fournir un repli lorsqu'une colonne peut être NULL
.
Par exemple, imaginez une table users
où certains utilisateurs n'ont pas fourni de numéro de téléphone:
SÉLECTIONNER nom, Fusionner (téléphone, «non fourni») comme contact_number Des utilisateurs;
Si phone
est NULL
, le résultat affichera 'Not provided'
à la place.
Vous pouvez enchaîner plusieurs valeurs:
SÉLECTIONNER nom, Coalesce (privrered_email, work_email, personnel_email, 'pas e-mail sur disque') comme e-mail Des utilisateurs;
Cela vérifie chaque champ de messagerie dans l'ordre et renvoie le premier non-nul.
Utilisation de coalesce () dans les calculs
Lors de l'exécution des opérations mathématiques, NULL
peut faire en sorte que les résultats entiers deviennent NULL
. COALESCE()
aide à éviter cela en substituant zéro ou un autre défaut.
Supposons que vous ayez un tableau sales
avec des termes de réduction et d'impôt facultatifs:
SÉLECTIONNER produit, Price Coalesce (taxe, 0) - Coalesce (remise, 0) comme final_price Des ventes;
Ici, les valeurs tax
ou discount
manquantes sont traitées comme zéro, donc le calcul fonctionne toujours.
Combiner avec d'autres fonctions et requêtes
COALESCE()
fonctionne bien dans JOIN
, WHERE
les clauses (indirectement) et ORDER BY
.
Par exemple, lors de l'adhésion aux profils et aux préférences des utilisateurs:
SÉLECTIONNER Name, Coalesce (P.Theme, 'Light') comme thème Des utilisateurs u Préférences de jointure de gauche p sur u.id = p.user_id;
Étant donné que LEFT JOIN
peut produire NULL
dans p.theme
, COALESCE()
assure une valeur par défaut.
Il est également utile dans les agrégations:
SÉLECTIONNER département, AVG (coalesce (salaire, 0)) comme avg_salary Des employés Groupe par département;
Bien que dans ce cas, l'utilisation 0
peut biaiser des moyennes, il est parfois une fois mieux exclue NULL
(en utilisant AVG(salary)
) selon le contexte.
Points clés pour se souvenir
-
COALESCE()
prend deux arguments ou plus - Il renvoie la première valeur non
NULL
- Tous les arguments sont évalués de gauche à droite
- Les types de données doivent être compatibles (MySQL tentera de les contraindre)
- Si tous les arguments sont
NULL
, le résultat estNULL
Remarque: COALESCE(a, b)
équivaut à IFNULL(a, b)
dans MySQL - mais COALESCE()
peut prendre plus de deux arguments et fait partie de la norme SQL, ce qui le rend plus portable entre les bases de données.
Fondamentalement, utilisez COALESCE()
chaque fois que vous avez besoin de gérer gracieusement les données manquantes. Il garde les requêtes propres et les résultats prévisibles.
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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

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

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

USEMYSQLENERPRISEAUDITPLUGINIFENONTER PRIXEDITIONBYABLINGITINCHIGFIGURATIONSWITHSERVER-AUDIT = FORCE_PLUS_PERMANENTANDCUMIDEVENTSVIASERVER_AUDIT_EVENTS; 2.Forfreealternatives, useperconaserverormariaDiaDbwithheiropen-SourceAuditpluginslikeaAut_Log; 3.

MySQL prend en charge les contraintes de contrôle pour forcer l'intégrité du domaine, efficace à partir de la version 8.0.16; 1. Ajoutez des contraintes lors de la création d'un tableau: utilisez crééTable pour définir les conditions de contrôle, telles que l'âge ≥ 18, salaire> 0, valeurs limites du département; 2. Modifiez le tableau pour ajouter des contraintes: utilisez alterTableAddConstraint pour limiter les valeurs de champ, telles que le nom non vide; 3. Utiliser des conditions complexes: Prise en charge la logique et les expressions multi-colonnes, telles que la date de fin ≥ Date et l'état d'achèvement doivent avoir une date de fin; 4. Supprimer les contraintes: utilisez alterTabledRopConstraint pour spécifier le nom à supprimer; 5. Remarques: MySQL8.0.16, Innodb ou Myisam doit être cité

Useamany-to-gyrelateeshipswithajunctiontabletolinkitemsandtagsviathreetables: éléments, tags, anditem_tags.2.whenaddingtags, checkforexistingtagsinthetagstable, insertifnecessary, thencreatemappingsinitem_tagsusingtransactionsforcencence..

Lorsque vous traitez avec de grandes tables, les performances MySQL et la maintenabilité sont confrontées à des défis, et il est nécessaire de commencer à partir de la conception structurelle, de l'optimisation des index, de la stratégie de sous-table de tableau, etc. 1. Concevoir raisonnablement les clés et les index primaires: il est recommandé d'utiliser des entiers auto-incrémentés comme clés principales pour réduire les scintillement de pages; Utiliser les index de superposition pour améliorer l'efficacité de la requête; Analyser régulièrement les journaux de requête lents et supprimer les index non valides. 2. Utilisation rationnelle des tables de partition: partition en fonction de la plage de temps et d'autres stratégies pour améliorer l'efficacité de la requête et de la maintenance, mais l'attention devrait être accordée aux problèmes de partitionnement et de coupe. 3. Envisagez de lire et d'écrire la séparation et la séparation des bibliothèques: la séparation de lecture et d'écriture atténue la pression sur la bibliothèque principale. La séparation de la bibliothèque et la séparation des tableaux conviennent aux scénarios avec une grande quantité de données. Il est recommandé d'utiliser des middleware et d'évaluer les problèmes de requête des transactions et des magasins croisés. La planification précoce et l'optimisation continue sont la clé.

Pour afficher toutes les bases de données dans MySQL, vous devez utiliser la commande showDatabases; 1. Après être connecté au serveur MySQL, vous pouvez exécuter les showDatabases; Commande pour répertorier toutes les bases de données auxquelles l'utilisateur actuel a la permission d'accéder; 2. 3. Vous pouvez également interroger et filtrer la base de données via selectSchema_namefrominformation_schema.schemata; Par exemple, l'exclusion de la base de données système pour afficher uniquement la base de données créée par les utilisateurs; Assurez-vous d'utiliser

Pour ajouter une clé primaire à une table existante, utilisez l'instruction altertable avec la clause AddPrimaryKey. 1. Assurez-vous que la colonne cible n'a pas de valeur nulle, pas de duplication et est définie comme notnull; 2. La syntaxe de clé primaire à colonne unique est le nom de table altertable addPrimaryKey (nom de colonne); 3. La syntaxe de la clé primaire de combinaison multi-colonnes est le nom de table altertable addPrimaryKey (colonne 1, colonne 2); 4. Si la colonne permet Null, vous devez d'abord exécuter Modify pour définir Notnull; 5. Chaque tableau ne peut avoir qu'une seule clé primaire et l'ancienne clé primaire doit être supprimée avant d'ajouter; 6. Si vous avez besoin de l'augmenter vous-même, vous pouvez utiliser Modify pour définir Auto_Increment. Assurer les données avant le fonctionnement

Vérifiez si le service MySQL est en cours d'exécution, utilisez SudosystemctlStatusMysQL pour confirmer et démarrer; 2. Assurez-vous que Bind-Address est défini sur 0,0.0.0 pour permettre les connexions distantes et redémarrer le service; 3. Vérifiez si le port 3306 est ouvert, vérifiez et configurez les règles de pare-feu pour permettre le port; 4. Pour l'erreur "AccessEnedy", vous devez vérifier le nom d'utilisateur, le mot de passe et le nom d'hôte, puis vous connecter à MySQL et interroger la table MySQL.User pour confirmer les autorisations. Si nécessaire, créez ou mettez à jour l'utilisateur et autorisez-le, comme l'utilisation de «votre_user» @ «%»; 5. Si l'authentification est perdue à cause de Caching_Sha2_Password
