Maison > base de données > tutoriel mysql > Comment renvoyer une valeur par défaut lorsqu'une requête SQL ne renvoie aucune ligne ?

Comment renvoyer une valeur par défaut lorsqu'une requête SQL ne renvoie aucune ligne ?

Patricia Arquette
Libérer: 2024-10-29 08:52:30
original
988 Les gens l'ont consulté

How to Return a Default Value When a SQL Query Returns No Rows?

Renvoyer une valeur par défaut lorsque la requête ne renvoie aucune ligne

Lorsque vous utilisez une requête SQL pour récupérer des données et qu'aucune ligne correspondante n'est trouvée, elle peut être utile pour renvoyer une valeur par défaut au lieu d'un résultat vide. Ceci est particulièrement utile lorsque vous souhaitez vous assurer que quelque chose est toujours affiché, même s'il n'y a aucune donnée à afficher.

Considérez l'instruction SQL suivante :

<code class="sql">SELECT `file`
FROM `show`, `schedule` 
WHERE `channel` = 1
  AND `start_time` <= UNIX_TIMESTAMP() 
  AND `start_time` > UNIX_TIMESTAMP()-1800
  AND `show`.`id` = `schedule`.`file` 
ORDER BY `start_time`
DESC LIMIT 1</code>
Copier après la connexion

Cette requête tente de récupérer l'élément planifié suivant pour un canal spécifique, mais si aucune ligne correspondante n'est trouvée, il renverra un résultat vide. Pour renvoyer une valeur par défaut, vous pouvez utiliser les fonctions COALESCE ou IFNULL :

<code class="sql">SELECT COALESCE(`file`, 'default.webm') `file` 
...

SELECT IFNULL(`file`, 'default.webm') `file` 
...</code>
Copier après la connexion

Cependant, ces solutions peuvent renvoyer un résultat vide si aucune ligne n'est trouvée. Pour garantir qu'une valeur par défaut est toujours renvoyée, vous pouvez utiliser une fonction d'agrégation, telle que MIN(), pour fournir une valeur NULL lorsqu'aucun enregistrement n'est sélectionné. L'instruction suivante utilise cette technique :

<code class="sql">SELECT IFNULL(MIN(`file`), 'default.webm') `file` 
...</code>
Copier après la connexion

En utilisant la fonction MIN(), vous pouvez garantir que NULL sera renvoyé si aucune ligne n'est sélectionnée. Ensuite, la fonction IFNULL() remplacera la valeur NULL par la valeur par défaut, garantissant que quelque chose soit toujours affiché.

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 de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal