Maison > base de données > tutoriel mysql > Comment faire pivoter des données à l'aide de plusieurs colonnes (user_id et lang) en SQL ?

Comment faire pivoter des données à l'aide de plusieurs colonnes (user_id et lang) en SQL ?

DDD
Libérer: 2024-12-18 02:34:13
original
463 Les gens l'ont consulté

How to Pivot Data Using Multiple Columns (user_id and lang) in SQL?

Pivotement des données avec plusieurs colonnes

Dans l'ensemble de données fourni, les données sont actuellement pivotées avec la colonne user_id comme identifiant principal. Cependant, le résultat souhaité est de faire pivoter les données avec à la fois user_id et lang comme identifiants principaux.

Pour y parvenir, la fonction PIVOT peut être utilisée. La fonction PIVOT prend une valeur agrégée et la regroupe par une ou plusieurs colonnes, créant une nouvelle colonne pour chaque groupe. Dans ce cas, les colonnes org et position seront agrégées et regroupées par langue.

Requête SQL

La requête SQL suivante montre comment faire pivoter les données à l'aide de plusieurs colonnes :

SELECT *
FROM source
PIVOT (
    MIN(org) AS org,
    MIN(position) AS position
    FOR lang IN('EN' AS en, 'FI' AS fi, 'SV' AS sv)
);
Copier après la connexion
  • La clause SELECT récupère toutes les colonnes de la table source.
  • La clause FROM spécifie la table source comme l'origine des données.
  • La clause PIVOT effectue l'opération de pivotement :

    • MIN(org) calcule la valeur minimale de la colonne org pour chaque groupe.
    • MIN(position) calcule la valeur minimale de la colonne de position pour chaque groupe.
    • FOR lang IN('EN' AS fr, 'FI' AS fi, 'SV' AS sv) définit les colonnes de regroupement et leurs alias correspondants.

Résultat

Le résultat de la requête est un ensemble de données pivoté avec les colonnes suivantes :

  • user_id : l'utilisateur identifiant.
  • org_en : l'organisation associée à la préférence pour la langue anglaise.
  • position_en : le poste associé à la préférence pour la langue anglaise.
  • org_fi : l'organisation associée à la préférence pour la langue finlandaise.
  • position_fi : le poste associé à la préférence linguistique finlandaise.
  • org_sv : l'organisation associée à la langue suédoise. préférence.
  • position_sv : Le poste associé à la préférence linguistique suédoise.

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