Diviser les valeurs séparées par des virgules dans SQLite : une approche d'expression de table commune (CTE)
Dans le domaine de la gestion des données, la nécessité de des valeurs séparées par des virgules (CSV) se produisent fréquemment. Pour SQLite, un système de base de données léger et populaire, cette tâche peut ne pas être aussi simple que dans d'autres environnements SQL en raison de l'absence de fonction substring() dédiée. Cependant, il existe une solution alternative qui exploite une expression de table commune (CTE).
Considérons le scénario suivant : nous avons une table avec une colonne "Catégorie" contenant des chaînes séparées par des virgules, et nous souhaitons extraire valeurs individuelles de chaque chaîne dans des lignes distinctes.
Un CTE est un ensemble de résultats nommé et temporaire qui peut être davantage référencé et manipulé au sein d'une seule requête. Dans notre cas, nous pouvons utiliser un CTE pour diviser récursivement les chaînes CSV et stocker les valeurs extraites dans une nouvelle table. Voici la requête :
WITH split(word, csv) AS ( -- 'initial query' SELECT '', 'Auto,A,1234444'||',' -- terminate with ',' indicating csv ending -- 'recursive query' UNION ALL SELECT substr(csv, 0, instr(csv, ',')), -- each word contains text up to next ',' substr(csv, instr(csv, ',') + 1) -- next recursion parses csv after this ',' FROM split -- recurse WHERE csv != '' -- break recursion once no more csv words exist ) SELECT word FROM split WHERE word!=''; -- filter out 1st/last rows
Cette requête divise les chaînes CSV à l'aide de la fonction instr() pour localiser la première virgule, extrait la sous-chaîne avant la virgule et s'appelle récursivement pour répéter le processus sur la partie restante. de la chaîne. La récursivité se termine lorsqu'il ne reste plus de virgules.
La sortie résultante contient les valeurs individuelles extraites des chaînes CSV d'origine, organisées en lignes :
Auto A 1234444
Cette approche fournit un outil puissant et moyen flexible de diviser des valeurs séparées par des virgules dans SQLite, ce qui en fait un outil précieux pour les tâches de manipulation de données.
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!