Leçon 3 : ajout de paramètres pour sélectionner plusieurs valeurs dans une liste (Générateur de rapports version 2.0)
Dans cette leçon, vous allez apprendre à modifier un paramètre pour qu'il accepte plusieurs valeurs. Ce principe est connu sous le nom de paramètres à valeurs multiples. Par défaut, un paramètre n'accepte qu'une seule valeur. Les paramètres que vous avez créé dans la leçon précédente, BusinessPersonID et DayoftheWeek, acceptent des valeurs uniques. Pour modifier un paramètre de manière à ce qu'il accepte plusieurs valeurs, vous devez savoir si le paramètre a été créé automatiquement à partir d'un paramètre de requête (par exemple BusinessPersonID) ou si vous l'avez créé manuellement à l'aide du volet Données du rapport (par exemple DayoftheWeek).
Pour modifier un paramètre de rapport de manière à ce qu'il accepte plusieurs valeurs, il vous suffit de définir une propriété de paramètre de rapport. Si le paramètre de rapport est basé sur un paramètre de requête, vous devez également modifier la requête. Si vous utilisez le paramètre dans un filtre, vous devez modifier l'opérateur de filtre pour spécifier un jeu de valeurs à la place d'une valeur unique.
Pour remplacer le dataset existant
Dans le volet Données du rapport, cliquez avec le bouton droit sur le dataset DataSet1, puis cliquez sur Requête.
Le concepteur de requêtes textuel s'ouvre.
Remplacez le texte par la requête suivante dans la zone de texte :
SELECT SH.OrderDate ,DATENAME(weekday, SH.OrderDate) as Weekday ,SH.SalesOrderNumber ,SD.OrderQty ,SD.LineTotal ,P.Name AS [Product] ,PS.Name AS [Subcategory] FROM Sales.SalesPerson SP INNER JOIN Sales.SalesOrderHeader AS SH ON SP.BusinessEntityID = SH.SalesPersonID INNER JOIN Sales.SalesOrderDetail AS SD ON SH.SalesOrderID = SD.SalesOrderID INNER JOIN Production.Product AS P ON SD.ProductID = P.ProductID INNER JOIN Production.ProductSubcategory AS PS ON PS.ProductSubcategoryID = P.ProductSubcategoryID INNER JOIN Production.ProductCategory AS PC ON PC.ProductCategoryID = PS.ProductCategoryID WHERE PC.Name = 'Clothing' AND (SH.OrderDate BETWEEN (@StartDate) AND (@EndDate)) AND SH.SalesPersonID IN (@BusinessPersonID)
Il s'agit de la même requête que précédemment, à la différence près que la condition a été modifiée et est passée d'égalité (=) à inclusion (IN) :
AND SH.SalesPersonID IN (@BusinessPersonID)
Cliquez sur le bouton Exécuter (!). Lorsque vous êtes invité à indiquer les paramètres de la requête, utilisez le tableau suivant pour entrer les valeurs. Le Concepteur de requêtes ne prend pas en charge le test des paramètres à valeurs multiples.
@StartDate
20010101
@EndDate
20030101
@BusinessPersonID
290
Cliquez sur OK.
Le jeu de résultats retourné pour le commercial Ranjit Varkey Chudukatil s'affiche avec BusinessPersonID = 290.
Pour modifier le paramètre de rapport BusinessPersonID en vue d'accepter plusieurs valeurs
Dans le volet Données du rapport, développez Paramètres, puis double-cliquez sur le paramètre BusinessPersonID.
Sélectionnez l'option Autoriser les valeurs multiples.
Cliquez sur OK.
Cliquez sur Aperçu. Le rapport s'exécute automatiquement. Tous les noms des commerciaux figurent dans la liste déroulante correspondant à BusinessPersonID.
[!REMARQUE]
Une valeur (Sélectionner tout) est fournie comme première valeur d'une liste déroulante des valeurs disponibles pour un paramètre à valeurs multiples. Utilisez cette case à cocher pour activer ou désactiver l'ensemble des valeurs.
Pour ajouter un nouveau dataset en vue d'alimenter les valeurs valides d'un paramètre de rapport
Passez en mode Conception.
Dans la barre d'outils du volet Données du rapport, cliquez sur Nouveau, puis sur Dataset. La boîte de dialogue Propriétés du dataset s'ouvre.
Dans la zone Nom, tapez WeekDaysfromQuery.
Dans Type de requête, vérifiez que l'option Texte est sélectionnée.
Cliquez sur Concepteur de requêtes, puis sur Modifier en tant que texte.
Dans le volet de requête, collez la requête suivante :
SET DATEFIRST 1; SELECT DISTINCT DATEPART(weekday, S.OrderDate) as WeekdayNumber, DATENAME(weekday, S.OrderDate) as Weekday FROM Sales.SalesOrderHeader S Order by WeekdayNumber
Cliquez sur le bouton Exécuter (!) de la barre d'outils du Concepteur de requêtes. Le jeu de résultats retourné affiche les nombres ordinaux et les jours de la semaine.
Cliquez sur OK deux fois pour quitter la boîte de dialogue Propriétés du dataset.
Le dataset WeekDaysfromQuery apparaît dans le volet Données du rapport.
Pour modifier un paramètre en vue d'accepter plusieurs valeurs, des valeurs par défaut et des valeurs valides
Dans le volet Données du rapport, développez Paramètres et double-cliquez sur le paramètre DayoftheWeek. La boîte de dialogue Propriétés du paramètre de rapport s'ouvre.
Sélectionnez Autoriser les valeurs multiples.
Cliquez sur Valeurs disponibles.
Sélectionnez Obtenir les valeurs à partir d'une requête.
Dans la liste déroulante Dataset, sélectionnez WeekDaysfromQuery.
Dans la liste déroulante Champ de valeur, sélectionnez WeekdayNumber.
Dans la liste déroulante Champ d'étiquette, sélectionnez Weekday.
Lorsque l'utilisateur sélectionne des valeurs de paramètre, il les sélectionne à partir des étiquettes, mais le rapport utilise les valeurs. Ceci est important lorsque vous définissez des valeurs par défaut ou un filtre. Les valeurs doivent être les valeurs entières du champ WeekdayNumber.
Cliquez sur Valeurs par défaut.
Sélectionnez Spécifier les valeurs.
Cliquez sur Ajouter.
Dans la zone Valeur, remplacez Vendredi par 6. Du fait que la valeur provient d'un dataset qui fournit à la fois le numéro et le nom du jour de la semaine, la valeur par défaut doit spécifier le numéro du jour de la semaine. La valeur 6 représente Samedi.
Cliquez sur Ajouter.
Dans la zone Valeur, tapez 7. Cette valeur représente Dimanche.
Cliquez sur OK.
Avant de pouvoir afficher un aperçu du rapport, vous devez modifier l'expression de filtre pour la table pour utiliser l'opérateur IN car le paramètre DayoftheWeek accepte les valeurs multiples.
Pour modifier un filtre en vue d'utiliser un paramètre à valeurs multiples
Dans le volet Données du rapport, cliquez avec le bouton droit sur DataSet1, puis cliquez sur Propriétés du dataset.
Cliquez sur Filtres. Un filtre a déjà été ajouté pour DayoftheWeek au cours de la Leçon 1.
Dans la liste déroulante Expression, vérifiez que la valeur est [Weekday].
Modifiez Opérateur en remplaçant le signe égal (=) par In.
Dans la zone Valeur, tapez [@DayoftheWeek.Label].
Spécifiez l'étiquette de paramètre de telle sorte que le nom de la semaine soit comparé au champ de l'étiquette et non au champ numérique du jour de la semaine.
Cliquez sur OK.
Le filtre de la table est désormais défini pour comparer la valeur du champ Weekday à l'étiquette du paramètre DayoftheWeek à l'aide de l'opérateur In. Lorsque vous choisissez que le paramètre du rapport soit à plusieurs valeurs, le filtre teste chaque ligne de la table pour vérifier que le champ Weekday existe dans la collection DayoftheWeek.
Cliquez sur Exécuter pour afficher un aperçu du rapport. Le rapport affiche le paramètre de rapport DaysoftheWeek avec les valeurs par défaut Samedi et Dimanche, qui sont les étiquettes des valeurs par défaut que vous avez spécifiées. Utilisez la liste déroulante pour sélectionner plusieurs valeurs pour le paramètre DayoftheWeek.
Étapes suivantes
Vous avez modifié avec succès les propriétés des paramètres de rapport de valeur unique en valeurs multiples. Vous avez effectué les modifications nécessaires dans une requête, un filtre et une expression pour utiliser une collection de paramètres à valeurs multiples. Vous avez appris à utiliser les paramètres à valeurs multiples dans une expression. Dans la leçon suivante, vous allez apprendre à créer des paramètres dont les valeurs sont alimentées sous condition, en fonction d'une valeur sélectionnée pour un précédent paramètre. Consultez Leçon 4 : ajout de paramètres en cascade (Générateur de rapports version 2.0).