|
08.10.2012, 14:00 | #1 |
Участник
|
Servus und Bongiorno!</p> Italien ist immer eine Reise wert. Gerade jetzt, da die Temperaturen locker 10 Grad über denen in Deutschland liegen. Neidisch? Wäre ich auch J Allerdings bin ich durchaus zum Arbeiten hier, was aber meine Freude darüber nur ein ganz klein wenig trübt.</p> Aber zum Thema: Mein werter Kollege Lars-Bo Christensen hat im NAV Team Blog zwei Artikel veröffentlicht, in denen es um die Umgestaltung und den Technologiewechsel der Excel Buffer-Funktionen geht. Wir nutzen dort nun, wie an den meisten Stellen in Dynamics NAV, keine Automations mehr, sondern .NET. Hier das Open XML SDK 2.0 für Microsoft Office. Mehr dazu in den folgenden englischsprachigen Artikeln.</p> Excel Buffer Using Open XML Instead of Excel Automation (Part 1 of 2)</p> Use Open XML to Extend the Excel Buffer Functionality (Part 2 of 2)</p> Hier soll es aber um etwas anderes gehen. Die in den Artikeln genutzten Tags NAV 2013, Office und Development sind aus meiner Sicht ein wenig emotionslos, da ein ganz entscheidender Hinweis fehlt: PERFORMANCE!</p> Das hat mein lieber Kollege Duilio Tacconi - und er bat mich ganz explizit, ihn als „Italian ***“ zu referenzieren – uns durch einige eigene Tests wissen lassen. Auch die Objekte stammen von Ihm. Vielen Dank Duilio </p> Und genau an dieser Performance-Demo möchte ich auch Sie teilhaben lassen. Sie basiert auf der Ausgabe der Tabelle 99000757 „Calendar Entry“ in eine Excel-Tabelle. Wenig funktional sinnvoll, aber effektiv für diesen Zweck. Im CRONUS finden sich in der Tabelle ca. 9400 Datensätze mit 18 Spalten. Also eine, wie ich finde, durchschnittliche Menge an Daten im Hinblick auf einen Export.</p> Die Testgestaltung ist recht übersichtlich. Im OnPreDataItem() Trigger werden die Überschriften ausgegeben:</p> </p> Dann im OnAfterGetRecord() die Zeilen:</p> </p> Und abschließend, im Trigger OnPostDataItem(), wird das Excel-Workbook erzeugt:</p> </p> Die Erzeugung ist in Dynamics NAV 2013 etwas unterschiedlich gelöst, deshalb hier noch einmal der dortige Quellcode:</p> </p> Die Laufzeit der Variante unter dem RoleTailored Client für Dynamics NAV 2009 R2 ist sehr… Sagen wir einfach, sie führt im Diagramm dazu, dass die Laufzeit unter Dynamics NAV 2013 nicht mehr sichtbar ist. Aus dem Grund lasse ich diese aus der Betrachtung heraus.</p> Prego!</p> </p> Der Export unter Dynamics NAV 2009 R2 dauert 7 Minuten und 14 Sekunden. Unter Dynamics NAV 2013 allerdings nur – aufgerundet – 32 Sekunden. Die Performance ist also um den Faktor 13 bis 14 besser, läuft also dramatisch schneller.</p> Geschuldet ist das vor allem der Open XML Implementierung, die um einiges schneller ist. Übrigens betrifft das viele Bereiche in Dynamics NAV 2013.</p> Um die Performance auch in Dynamics NAV 2009 zu steigern, möchte ich Ihnen noch den folgenden Artikel meiner Kollegin Jasminka Thunes ans Herz legen: Export to Excel on Dynamics NAV: RTC.</p> Bis zum nächsten Post, Arrividerci!</p> </p> Carsten Scholling </p> Microsoft Dynamics Germany Microsoft Customer Service und Support (CSS) EMEA</p> Email: cschol@microsoft.com Microsoft Connect: http://connect.microsoft.com Online Support: http://www.microsoft.com/support Sicherheitsupdates: http://www.microsoft.de/sicherheit</p> Microsoft Deutschland GmbH Konrad-Zuse-Straße 1 D-85716 Unterschleißheim http://www.microsoft.de</p><div style="clear:both;"></div>Далее
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору. |
|