Maison >base de données >tutoriel mysql >Comment renvoyer une valeur par défaut lorsqu'une requête SQL ne renvoie aucune ligne ?
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>
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>
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>
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!