Reporting Services: L’avenir du Report Builder

Brian Welcker, membre de l’équipe de développement SSRS, nous permet enfin de voir clair dans la forêt des outils qui seront proposés par Reporting Services 2008.

En résumé, le Report Builder a vocation à disparaître pour être remplacé par le nouveau Report Designer à la sauce Office 12. Ce dernier intègrera l’ensemble des fonctionnalités disponibles dans le concepteur de rapport Visual Studio 2008.

Néanmoins le Report Builder actuel sera toujours disponible dans SQL Server 2008 pour laisser le temps aux refractaires de se mettre à la page!

Plus de détails dans cet article: http://blogs.msdn.com/bwelcker/archive/2007/12/11/transmissions-from-the-satellite-heart-what-s-up-with-report-builder.aspx

Ajouté le 23 juillet 2008: Un autre article permettant de voir plus clair entre le Report Designer, le Report Builder 1.0 et le Report Builder 2.0 => http://blogs.msdn.com/sqlrsteamblog/archive/2008/06/30/building-the-new-builder.aspx

Reporting Services: Interrogation de listes Sharepoint

Intégrer des rapports SSRS dans MOSS ou WSS, c’est facile… Interroger du contenu Sharepoint depuis un rapport SSRS, c’est une autre histoire. Etrange d’ailleurs que MS ne propose pas de connecteur permettant de le faire nativement.
Le truc consiste donc à interroger les webservices mis à disposition par Sharepoint pour arriver au résultat escompté.

Voici donc la marche à suivre:

    Dans la source de données, utiliser le connecteur XML en précisant l’URL d’accès au Webservice Lists.asmx de votre serveur Sharepoint.

Dans les informations d’identifications, seules les options utiliser l’authentification Windows et Ne pas demander les informations d’identification sont utilisables. Il convient donc de s’assurer que l’utilisateur qui exécute le rapport dispose des droits nécessaires pour interroger le contenu Sharepoint.

Voyons en premier lieu comment créer un dataset basé sur cette source de données qui interroge la méthode GetListCollection. Cette dernière permet de lister les bibliothèques de documents disponibles.
<Query> <Method Namespace=”http://schemas.microsoft.com/sharepoint/soap” Name=”GetListCollection” /></Query>

Pour obtenir le détail du contenu d’une de ces listes, c’est la méthode GetListItems qu’il faut interroger. Celle-ci prend en entrée les paramètres listName (guid ou nom d’une liste) et viewName (guid d’une vue, vue par défaut si null). <Query> <Method Namespace=”http://schemas.microsoft.com/sharepoint/soap/” Name=”GetListItems”/><SoapAction>http://schemas.microsoft.com/sharepoint/soap/GetListItems</SoapAction> <Parameters> <Parameter Name=”listName”> <DefaultValue>/</DefaultValue> </Parameter> <Parameter Name=”viewName”> <DefaultValue>/</DefaultValue> </Parameter> </Parameters></Query>Ne pas oublier de créer les deux paramètres correspondant dans le dataset. Si ceux-ci n’existent pas, la requête ne fonctionnera pas.

On peut maintenant tester l’exécution de la requête. On commence par renseigner les valeurs des paramètres.

Et voilà le résultat!

Reporting Services: Astuce pour gérer les totaux d’une matrice

Une question qui revient souvent sur SSRS: comment utiliser des formules différentes dans les lignes de détail et le total d’une matrice ? La réponse se trouve dans l’utilisation de la fonction InScope().

Prenons une matrice qui nous affiche un total des ventes par clients (en ligne). Celle-ci se présente par défaut comme suit:
L’affichage qui en résulte est le suivant:

Le total utilise donc la même formule que les lignes de détail, à savoir une somme sur les montants.
Nous pourrions imaginer vouloir afficher une moyenne plutôt qu’un somme dans cette zone.
Notre regroupement sur les comptes clients se nommant grpAccountNumber, il faut modifier l’expression de la zone de texte affichant les données comme suit:
=Iif(InScope(“grpAccountNumber”),Sum(Fields!TotalDue.Value),Avg(Fields!TotalDue.Value))
Voilà le résultat obtenu:

Cette exemple peut se décliner à volonté pour permettre de différencier les différents niveaux de regroupement par exemple.
A noter que tout ceci sera obsolète avec l’apparition de l’objet Tablix dans le Report Deisgner de SQL Server 2008 qui permettra une plus grande souplesse dans la gestion des matrices.

Reporting Services: Ecran bleu à l’impression d’un rapport

Lors de l’utilisation du bouton d’impression intégré au portail Reporting Services, certains d’entre vous ont peut être eu la désagréable surprise d’obtenir un écran bleu et de devoir rebooter la machine.

Microsoft a sorti un pach qui permet de résoudre ce bug:
http://support.microsoft.com/Default.aspx?kbid=935843

Reporting Services: Bug du sélecteur de date

Je vous fais part d’un bug que j’avais constaté chez un client le mois dernier: dans un rapport prenant en entrée un paramètre de type date:
- Aucun souci lorsque l’on consulte celui-ci via le portail RS.
- En utilisant la WebPart “visionneuse de rapport” pour SharePoint, le sélecteur de date renvoyait toujours une date au format US, forçant l’utilisateur à modifier celle-ci manuellement :(

Pour faire simple, cela fonctionnait lorsque l’on passait par le répertoire virtuel “Reports” pour attaquer le rapport. Par contre, bug sur le format de date en passant par “ReportServer”.

Et bien, bonne nouvelle, le dernier correctif apporté à SQL Server 2005 résout ce bug:
http://support.microsoft.com/?kbid=936305 :)

Il n’est pas téléchargeable directement, vous devez passer par le support pour l’obtenir.

Microsoft rachète les composants de visualisation des données de Dundas

C’est une très bonne nouvelle pour tous les développeurs de rapports Reporting Services. SSRS intègrera certainement à partir de la version 2008 les excellents graphes, jauges, cartes et autres contrôles développés par Dundas.

Plus de détail ici: http://blogs.msdn.com/bimusings/archive/2007/06/04/microsoft-acquires-dundas-s-data-visualization-components-sql-2008-news-download-ctp3.aspx

Reporting Services et SAP BW (IV) : Hiérarchie de présentation

Le query designer du Bex permet d’obtenir une hiérarchie de présentation lors de la génération des résultats d’une query:

Le code MDX généré par Reporting Services ne permet pas d’obtenir directement ce type de présentation. Dans ce cas de figure, il faut donc parfois effectuer 2 requêtes:

  • une pour l’obtention des données.
  • une pour l’obtention de la hiérarchie.