Samstag, Februar 23, 2008

Sql Server Reporting Service Multivalue und die Integration in SharePoint

Am Wochende habe ich mich intensiv mit dem Sql Server Reporting Service beschäftigt, ich muss sagen, dass ich mir mal endlich richtig Zeit genommen habe und auch einige Tricky-Sachen gelöst habe. (Natürlich durch googlen) Letztendlich wollte ich dem Kunden ermöglichen in unserer Datenbank nach Einlieferungsnummern zu suchen, um so simple Fragen „Was ist mit meinen Daten passiert?“ selbst zu lösen. Der erste Schritt war das überfliegen eines Tutorials zu dem Thema. Das Beste was ich kenne, sind diese: Beginning SQL Server 2005 Reporting Services Part 1 - Building and deploying basic reports , Beginning SQL Server 2005 Reporting Services Part 2 , Beginning SQL Server 2005 Reporting Services Part 3 - The Chart Control und Beginning SQL Server Reporting Services Part 4 alle Artikel sind von Steve Joubert . Ich kann jedem diese Artikel nur Empfehlen.

Nun aber zu den eigentlichen Problemstellungen. Ich bin nun nicht gerade der beste zum Schreiben von Sql Statements, einige meiner Kollegen werden noch mit erschrecken zurückdenken. … Immer wenn ich an eine Prozedur in der DB ran wollte, weil es mir zu langsam ging, haben die Kollegen das Priorisiert gemacht, quasi gleich, denn immer nachdem ich an der DB war musste alles aufgeräumt werden … Die Statements gingen recht leicht, hätte ich gar nicht gedacht, ich hatte mir allerdings die Woche auch einige Tricks für die Erstellung und das zusammen setzen von komplexen Statements von einem Kollegen geholt. Für die Reporting Services sind die Datenquellen das wichtigste bei der Realisierung. Gerade bei der Realisierung von Online-Statements sollte man auf schnelle Ausfrührung und möglichst limitierte Daten achten. Gerade bei großen Ergebnismengen ist die Aufbereitung problematisch und zeitintensiv.

Für die Darstellung habe ich anschließend ein Drill Down Report gewählt, der über 4 Ebene/Gruppen geht, so wird die Anzeige kompakt und doch informativ.

Die Anforderung das MultiValue-Feld zu realisieren, war zunächst extrem schwierig umzusetzen. Den besten Tipp habe ich auf dem Blog RDA Corp – BI and Sql Server gefunden. Man benötigt für die Verwendung des Parameters die Prozedur um die Werte zurück zubekommen.

Parameter Expression: Join(Parameters!Param.Value, ",")

Statement:
[tableSynonym].[KeyColumn] IN
(
SELECT [columniID]
FROM [schema].[table] tb, [dbo].[Split](@ItemList, ',') tmp
WHERE patindex('%' + tmp.Item + '%', tb.[KeyColumn]) > 0
)

Prozedur: ( RDA Corp – BI and Sql Server )
CREATE FUNCTION [dbo].[Split]
(
@ItemList NVARCHAR(8000 ),
@delimiter CHAR(1 )
)
RETURNS @IDTable TABLE (Item VARCHAR(200 ))
AS
BEGIN
DECLARE @tempItemList NVARCHAR(8000 )
SET @tempItemList = @ItemList
 
DECLARE @i INT
DECLARE @Item NVARCHAR(8000 )
SET @tempItemList = REPLACE (@tempItemList, @delimiter + ' ', @delimiter )
SET @i = CHARINDEX(@delimiter, @tempItemList )
WHILE (LEN(@tempItemList) > 0 )
BEGIN
IF @i = 0
SET @Item = @tempItemList
ELSE
SET @Item = LEFT(@tempItemList, @i - 1 )
INSERT INTO @IDTable(Item) VALUES(@Item )
IF @i = 0
SET @tempItemList = ''
ELSE
SET @tempItemList = RIGHT(@tempItemList, LEN(@tempItemList) - @i )
SET @i = CHARINDEX(@delimiter, @tempItemList )
END
RETURN
END

Nach dem der Report so richtig gut funktionierte, war es Zeit die Integration in den Sharepoint durchzuführen. Es gibt von MS ein Report Service WebPart für Sharepoint, außerdem hat man die Möglichkeit mit dem .NET FX2 das ReportViewer Webpart zu nutzen. Ich hatte zu erst versucht das fertige WebPart zu nutzen, bin dabei allerdings gescheitert, außerdem habe ich damit nicht die Möglichkeit kleinere Modifikationen durchzuführen. Also einen kleinen Wrapper für erstellt, der Connections-Akzeptiert, Parameter von einer anderen Quelle empfangen kann und über ein Parameter-Mapping verfügt. Man kann im Viewer-Control sehr schön die Ansichten modifizieren, so sind bei uns die Parameter nicht vorhanden, da diese durch ein anderes WebPart geliefert werden. Bisschen Probleme hat mir die Anzeige gemacht, da die Scrollbalken immer störten, leider konnte ich nicht einfach die gesamte Seitenhöhe verwenden, hier kann evtl. ein JavaScript helfen, aber es gibt wichtigeres.

Nach dem auch der Schritt erledigt war, hat ein Kollege sich den Report noch mal vorgenommen und versucht die Abfragen zu optimieren (ohne den Plan zu nutzen). Außerdem wurde das zugehörige DataWarehouse angepasst, um Datenstrukturen bereite optimiert vorzuhalten.

Man muss einfach sagen, dass die Reportings Services so viele extrem schöne Feature mitliefern, dass man diese einfach viel mehr nutzen sollte. Die Exportformate sehen sehr schick aus, richtig Klasse finde ich die Excel-Version des Reports. Man sollte bei der exzessiven Nutzung aber unbedingt die Serverresourcen im Auge behalten. Reporting kann sehr Rechenintensiv sein! Sorry, dass ich kein Bild vom Report einfüge, aber leider sind sehr viele vertrauliche Daten enthalten.

Hier noch eine weitere Webseite http://www.gotreportviewer.com/ mit vielen Tipps und Tutorials.

Donnerstag, Februar 21, 2008

Windows Vista Service Pack1

Wow, seit heute 19:30 zieht mein Rechner das Service Pack 1 über Windows Update. Ich bin vielleicht schockiert und habe schnell noch eine Sicherung des Rechners angeschmissen. Das Update wird gezogen, ohne das eine Veränderung an meinem System gemacht wurde. Jetzt bin ich mal gespannt, ob alles erfolgreich ist und danach noch alles ordentlich funktioniert. Ich vermute, dass das SP1 für x64 eher freigegeben wurde, da es schon am Anfang höhere Anforderungen an die Treiber gestellt hat.

Nun kann ich aber leider nicht den eigentlichen Blog-Post weiterschreiben, weil der Rechner gut beschäftigt ist. Ich habe schon einiges zusammengetragen für den Post und denke, dass ich ihn spätestens am Samstag fertig habe, wenn der Rechner nicht das zeitliche segnet.

Also bis auf weiteres Daumen drücken und die Meldungen der letzten Tage vergessen. (Loop restart with pre sp1, recovery after installing sp1, ...)


Update: Hab gestern bis kurz vor 23:00 das Backup laufen lassen und nach dem es abgeschlossen war das SP1 angeworfen. Nach dem ersten Schreck heute morgen, Rechner war nicht heruntergefahren, und den 2 reboots danach war alles Spitze. Service Pack ist installiert, System läuft noch. Bis jetzt weder positives noch negatives gemerkt. ICh freue mich schon darauf, wenn kein Delay mehr bei den Browser-Dialogs ist. Ansonsten geht nun die ganz normale Arbeit weiter.

Montag, Februar 18, 2008

Slowly blogging

In letzter Zeit habe ich das Bloggen etwas vernachlässigt, ich habe mich einfach z sehr in Arbeit eingedeckt. Ich wollte endlich unsere Portal-Anwendung live bringen. Dies hat aber leider nicht so richtig geklappt. Momentan gibt es erneut Diskussionen über die Navigation. Außerdem habe ich versucht noch einige Gimmicks einzubauen, allerdings bin ich mir noch nicht sicher, ob diese Funktion enthalten bleibt.

Ich habe immer enorm Schwierigkeiten, sobald ich alleine bin und Zeit zum nachdenken habe. Sie ist bestimmt schwer beschäftigt und hat für nichts Zeit, ich wünschte mir trotzdem, dass ich sie mal wieder sehe. Ich würde so gerne Informationen über sie hören und lesen, natürlich am liebsten sie treffen. Nur gleichzeitig macht mir das so Angst. Ich vermisse die Gefühle vom letzten Jahr, die Zeit mit ihr.

Am Wochenende habe ich eine tolle Zeit mit meinen besten Freunden verbracht. Die 4 sind schon was ganz spezielles und die beiden kleinen schaffen es 100ig einen abzulenken. Am Freitag habe ich mich zu dem mal mit Ex-Kollegen getroffen, die einige lustige Sachen über Timing bei meinem alten Arbeitgeber erzählt. Leider ist der Grund für die Erheiterung eigentlich nicht lustig.

Auf Arbeit läuft es momentan wie auf einem Schiff oder Achterbahn, es geht auf und ab oder auch hin und her. Es macht Spass, aber manchmal ist es einfach frustrierend. Wir haben seit 2 Wochen Storage, der Storage soll für unsere Virtualisierungsserver als Speicherplatz dienen. Leider musste wir feststellen, dass es nicht anzuschließen geht, zumindest bekommen wir das nicht hin.

Ich will die nächsten Tage einen kurzen Blog-Eintrag zum Sql Server Reporting Service erstellen, bzw. die Integration in ASP.NET/WSS.

Ich werde mir in nächster Zeit mehr Mühe geben, um regelmäßiger und pünktlicher zu bloggen.

Sonntag, Februar 10, 2008

ASP.NET Membership Provider custom password reset

Ich hatte schon länger Probleme mit dem Zurücksetzen des Passwortes in einer ASP.NET-Anwendung. Benutzt man nicht das Standardverhalten in dem man altes Passwort und neues Passwort abfragt, so hat man richtig Probleme ein Passwort-Reset durchzuführen. Diese Woche habe ich noch mal gegooglet und auch 2 Blog-Einträge mit einer ähnlichen Problemstellung gefunden. Der Blog-Eintrag „MembershipUser.ChangePasswort“ von Simon Steckermeier hat eine schöne Erläuterung der Problemstellung, einige kleine Macken hatten aber die Lösungen. Was passiert, wenn das Passwort nicht gesetzt werden kann, weil es die Regeln verletzt?

Also konnte ich die Lösung nicht so verwenden. Aber ein wenig ausprobieren und eine Lösung war gefunden. Allerdings kann man diese Lösung nicht mit Hashed-Passwords verwenden. Folgende Code-Zeilen sind meine Lösung:

string oldPW = Membership.Provider.GetPassword(this.txtUserName.Text, null);

string generatedPW = Membership.Provider.ResetPassword(this.txtUserName.Text, null);

try

{

Membership.GetUser(this.txtUserName.Text).ChangePassword(generatedPW, pw);

}

catch (ArgumentException ex)

{

Membership.GetUser(this.txtUserName.Text).ChangePassword(generatedPW, oldPW);

throw;

}

Unbedingt zu beachten ist, dass die web.config für die Provider-Einstellung korrekt eingestellt ist! Hier auch die Web.config-Attribute, die für den Provider entsprechend eingestellt sein müssen: enablePasswordRetrieval="true" enablePasswordReset="true" requiresQuestionAndAnswer="false" passwordFormat="Encrypted"

Im Anschluss ist alles super und die Password Veränderung kann man ansteuern, wie man möchte.