Partager via


Fonctions du Générateur de rapports - Fonction Previous dans un rapport paginé (Générateur de rapports)

S’applique à : Générateur de rapports Microsoft (SSRS) Power BI Report Builder Report Designer dans SQL Server Data Tools

Retourne la valeur ou la valeur d’agrégation spécifiée pour l’instance précédente d’un élément dans l’étendue spécifiée dans un rapport paginé.

Notes

Il est possible de créer et de modifier des fichiers de définition de rapports (.rdl) paginés dans le Générateur de rapports Microsoft, dans Power BI Report Builder et dans le Concepteur de rapports de SQL Server Data Tools.

Syntaxe

  
Previous(expression, scope)  

Paramètres

expression
(Variant or Binary) Expression à utiliser pour identifier les données et pour laquelle récupérer la valeur précédente, par exemple Fields!Fieldname.Value ou Sum(Fields!Fieldname.Value).

scope
(Chaîne) Facultatif. Nom d’un groupe ou d’une région de données, ou valeur Null (Nothing dans Visual Basic), qui spécifie l’étendue à partir de laquelle récupérer la valeur précédente spécifiée par expression.

Type de retour

Retourne une valeur Variant ou Binary.

Notes

La fonction Previous retourne la valeur précédente de l’expression évaluée dans l’étendue spécifiée après que cette dernière a été triée et filtrée correctement.

Si expression ne contient pas d’agrégat, la fonction Previous utilise par défaut l’étendue actuelle de l’élément de rapport.

Dans le groupe de détails, utilisez Previous pour spécifier la valeur d’une référence de champ dans l’instance précédente de la ligne de détails.

Notes

La fonction Previous ne prend en charge que les références de champ dans le groupe de détails. Par exemple, dans une zone de texte du groupe de détails, =Previous(Fields!Quantity.Value) retourne les données du champ Quantity de la ligne précédente. Cette expression sur la première ligne retourne une valeur Null (Nothing dans Visual Basic).

Si expression contient une fonction d’agrégation qui utilise une étendue par défaut, Previous agrège les données de l’instance précédente de l’étendue spécifiée dans l’appel de la fonction d’agrégation.

Si expression contient une fonction d’agrégation qui spécifie une étendue autre que celle par défaut, le paramètre scope de la fonction Previous doit être une étendue contenante pour l’étendue spécifiée dans l’appel de la fonction d’agrégation.

Vous ne pouvez pas utiliser les fonctions Level, InScope, Aggregate et Previous dans le paramètre expression. La spécification du paramètre recursive pour une fonction d’agrégation n’est pas prise en charge.

Pour plus d’informations, consultez Référence aux fonctions d’agrégation (Générateur de rapports et SSRS) et Étendue des expressions pour les totaux, les agrégats et les collections intégrées (Générateur de rapports et SSRS).

Exemples

Description

L’exemple de code ci-dessous, quand il est placé sur la ligne de données par défaut d’une région de données, fournit la valeur du champ LineTotal de la ligne précédente.

Code

=Previous(Fields!LineTotal.Value)  

Description

L'exemple suivant montre une expression qui calcule la somme des ventes réalisées au cours d'un jour spécifique du mois et la valeur précédente pour le même jour du mois d'une année précédente. L’expression est ajoutée à une cellule d’une ligne qui appartient au groupe enfant GroupbyDay. Son groupe parent est GroupbyMonth, ayant lui-même le groupe parent GroupbyYear. L'expression affiche les résultats pour GroupbyDay (étendue par défaut), puis pour GroupbyYear (le parent du groupe parent GroupbyMonth).

Par exemple, pour une région de données avec un groupe parent nommé Year, son groupe enfant nommé Monthet son groupe enfant nommé Day (3 niveaux imbriqués). L’expression =Previous(Sum(Fields!Sales.Value,"Day"),"Year") d’une ligne associée au groupe Day retourne la valeur des ventes réalisées le même jour du même mois de l’année précédente.

Code

=Sum(Fields!Sales.Value) & " " & Previous(Sum(Fields!Sales.Value,"GroupbyDay"),"GroupbyYear")