Combinaison de colonnes de caractères (2) dans des requêtes PostgreSQL
Lorsque vous travaillez avec des instructions PostgreSQL SELECT
, la combinaison de colonnes de caractères (2) peut présenter un défi en raison de l'opérateur de concaténation (||
) nécessitant au moins une entrée de chaîne.
Une solution consiste à convertir explicitement l'une des colonnes caractère(2) en type de données text
avant la concaténation. Cela garantit que les deux entrées sont des types de chaîne, permettant une concaténation réussie. Par exemple :
<code class="language-sql">SELECT a::text || b AS combined_column FROM foo;</code>
Alternativement, la fonction concat_ws()
offre une solution robuste. Cette fonction gère plusieurs entrées, les concaténe avec un séparateur spécifié et gère gracieusement les valeurs NULL. Cela empêche les résultats NULL même si l'une des colonnes d'entrée contient une valeur NULL. Exemple :
<code class="language-sql">SELECT concat_ws(', ', a, b) AS combined_column FROM foo;</code>
Pour les scénarios exigeant des fonctions immuables (par exemple, pour les index, les colonnes générées ou le partitionnement), une fonction immuable personnalisée basée sur concat_ws()
ou une stratégie alternative, telle que l'ajout et la mise à jour d'une nouvelle colonne combinée via un déclencheur de base de données, est recommandé.
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!