Types de Fonctions de Fenêtre
Explorons brièvement les principaux types de fonctions de fenêtre utilisées en SQL.
Fonctions d'agrégation
Il s'agit des fonctions d'agrégation standard (AVG
, SUM
, MAX
, MIN
, COUNT
) utilisées dans un contexte de fenêtre. Nous avons déjà utilisé ce type de fonction de fenêtre dans le chapitre précédent.
Fonctions de classement
Les fonctions de classement en SQL sont un type de fonction de fenêtre qui permet d'attribuer un rang à chaque ligne au sein d'une partition d'un ensemble de résultats. Ces fonctions sont particulièrement utiles pour effectuer des calculs et des analyses ordonnés.
-
RANK()
: Attribue un rang unique à chaque ligne distincte dans la partition selon la clauseORDER BY
. Les lignes ayant des valeurs identiques reçoivent le même rang, ce qui crée des sauts dans la séquence de classement ; -
DENSE_RANK()
: Semblable à RANK(), mais sans sauts dans la séquence de classement ; -
NTILE(n)
: Divise les lignes d'une partition ordonnée enn
groupes et attribue un numéro de groupe à chaque ligne.
Exemple
Nous allons classer les ventes selon le champ Amount
pour chaque ProductID
par ordre croissant en utilisant la fonction DENSE_RANK()
:
12345678SELECT sales_id, product_id, sales_date, amount, DENSE_RANK() OVER (PARTITION BY product_id ORDER BY amount DESC) AS dense_rank_amount FROM Sales;
La table de résultats contient toutes les informations de la table principale ainsi qu'une colonne supplémentaire qui indique le rang de chaque vente pour le produit concerné.
Fonctions de comparaison de valeurs
Les fonctions de comparaison de valeurs dans SQL sont utilisées pour comparer les valeurs de la ligne courante avec les valeurs d'autres lignes au sein de la même partition.
Ces fonctions sont particulièrement utiles pour analyser des tendances, effectuer des calculs basés sur des lignes adjacentes ou accéder à des valeurs spécifiques de lignes dans une fenêtre définie.
Il existe plusieurs fonctions de comparaison de valeurs en SQL :
LAG()
: Récupère la valeur d'une ligne précédente dans le jeu de résultats sans nécessiter d'auto-jointure ;LEAD()
: Récupère la valeur d'une ligne suivante dans le jeu de résultats sans nécessiter d'auto-jointure ;FIRST_VALUE()
: Retourne la valeur de la première ligne dans la fenêtre ;LAST_VALUE()
: Retourne la valeur de la dernière ligne dans la fenêtre.
Exemple
Utilisons la fonction de fenêtre de comparaison de valeurs LAG()
pour calculer la variation du montant des ventes par rapport à la vente précédente pour chaque produit :
1234567891011SELECT sales_id, product_id, sales_date, amount, LAG(amount, 1) OVER (PARTITION BY product_id ORDER BY sales_date) AS previous_amount, amount - LAG(amount, 1) OVER (PARTITION BY product_id ORDER BY sales_date) AS amount_change FROM Sales ORDER BY product_id, sales_date;
Ainsi, il est possible d'extraire facilement des informations sur les différences de ventes pour chaque produit sans utiliser de sous-requêtes ou de procédures stockées.
Il est également possible de calculer les différences pour l'ensemble des ventes sans partitionnement à l'aide de la requête suivante :
123456789SELECT sales_id, product_id, sales_date, amount, LAG(amount, 1) OVER (ORDER BY sales_date) AS previous_amount, amount - LAG(amount, 1) OVER (ORDER BY sales_date) AS amount_change FROM Sales;
Vous pouvez constater que nous n'avons pas inclus la clause PARTITION BY
dans le bloc OVER
. Cela signifie que nous ne souhaitons pas obtenir les valeurs précédentes uniquement pour un produit particulier, mais pour toutes les ventes de la table.
Merci pour vos commentaires !
Demandez à l'IA
Demandez à l'IA
Posez n'importe quelle question ou essayez l'une des questions suggérées pour commencer notre discussion
Can you explain the difference between RANK() and DENSE_RANK() in more detail?
What are some practical use cases for value comparison window functions like LAG() and LEAD()?
Could you provide more examples of window functions in SQL?
Awesome!
Completion rate improved to 4.35
Types de Fonctions de Fenêtre
Glissez pour afficher le menu
Explorons brièvement les principaux types de fonctions de fenêtre utilisées en SQL.
Fonctions d'agrégation
Il s'agit des fonctions d'agrégation standard (AVG
, SUM
, MAX
, MIN
, COUNT
) utilisées dans un contexte de fenêtre. Nous avons déjà utilisé ce type de fonction de fenêtre dans le chapitre précédent.
Fonctions de classement
Les fonctions de classement en SQL sont un type de fonction de fenêtre qui permet d'attribuer un rang à chaque ligne au sein d'une partition d'un ensemble de résultats. Ces fonctions sont particulièrement utiles pour effectuer des calculs et des analyses ordonnés.
-
RANK()
: Attribue un rang unique à chaque ligne distincte dans la partition selon la clauseORDER BY
. Les lignes ayant des valeurs identiques reçoivent le même rang, ce qui crée des sauts dans la séquence de classement ; -
DENSE_RANK()
: Semblable à RANK(), mais sans sauts dans la séquence de classement ; -
NTILE(n)
: Divise les lignes d'une partition ordonnée enn
groupes et attribue un numéro de groupe à chaque ligne.
Exemple
Nous allons classer les ventes selon le champ Amount
pour chaque ProductID
par ordre croissant en utilisant la fonction DENSE_RANK()
:
12345678SELECT sales_id, product_id, sales_date, amount, DENSE_RANK() OVER (PARTITION BY product_id ORDER BY amount DESC) AS dense_rank_amount FROM Sales;
La table de résultats contient toutes les informations de la table principale ainsi qu'une colonne supplémentaire qui indique le rang de chaque vente pour le produit concerné.
Fonctions de comparaison de valeurs
Les fonctions de comparaison de valeurs dans SQL sont utilisées pour comparer les valeurs de la ligne courante avec les valeurs d'autres lignes au sein de la même partition.
Ces fonctions sont particulièrement utiles pour analyser des tendances, effectuer des calculs basés sur des lignes adjacentes ou accéder à des valeurs spécifiques de lignes dans une fenêtre définie.
Il existe plusieurs fonctions de comparaison de valeurs en SQL :
LAG()
: Récupère la valeur d'une ligne précédente dans le jeu de résultats sans nécessiter d'auto-jointure ;LEAD()
: Récupère la valeur d'une ligne suivante dans le jeu de résultats sans nécessiter d'auto-jointure ;FIRST_VALUE()
: Retourne la valeur de la première ligne dans la fenêtre ;LAST_VALUE()
: Retourne la valeur de la dernière ligne dans la fenêtre.
Exemple
Utilisons la fonction de fenêtre de comparaison de valeurs LAG()
pour calculer la variation du montant des ventes par rapport à la vente précédente pour chaque produit :
1234567891011SELECT sales_id, product_id, sales_date, amount, LAG(amount, 1) OVER (PARTITION BY product_id ORDER BY sales_date) AS previous_amount, amount - LAG(amount, 1) OVER (PARTITION BY product_id ORDER BY sales_date) AS amount_change FROM Sales ORDER BY product_id, sales_date;
Ainsi, il est possible d'extraire facilement des informations sur les différences de ventes pour chaque produit sans utiliser de sous-requêtes ou de procédures stockées.
Il est également possible de calculer les différences pour l'ensemble des ventes sans partitionnement à l'aide de la requête suivante :
123456789SELECT sales_id, product_id, sales_date, amount, LAG(amount, 1) OVER (ORDER BY sales_date) AS previous_amount, amount - LAG(amount, 1) OVER (ORDER BY sales_date) AS amount_change FROM Sales;
Vous pouvez constater que nous n'avons pas inclus la clause PARTITION BY
dans le bloc OVER
. Cela signifie que nous ne souhaitons pas obtenir les valeurs précédentes uniquement pour un produit particulier, mais pour toutes les ventes de la table.
Merci pour vos commentaires !