Maison > base de données > tutoriel mysql > Comment puis-je diviser des valeurs séparées par des virgules dans SQLite à l'aide d'une expression de table commune (CTE) ?

Comment puis-je diviser des valeurs séparées par des virgules dans SQLite à l'aide d'une expression de table commune (CTE) ?

Barbara Streisand
Libérer: 2024-12-31 22:01:17
original
744 Les gens l'ont consulté

How Can I Split Comma-Separated Values in SQLite Using a Common Table Expression (CTE)?

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
Copier après la connexion

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
Copier après la connexion

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!

source:php.cn
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