Dynamics AX Blog - Dynamics AX 4.0 - Beiträge von 2008

Momentan angezeigt werden nur Beiträge, welche für die Dynamics AX-Version »Dynamics AX 4.0« relevant sind. Filter entfernen

RSS-Feed dieser Version
Momentan angezeigt werden nur Beiträge von »2008«.

Dynamics AX: Die Debug-Klasse

Mit der Debug-Klasse stellt Microsoft dem Dynamics AX-Entwickler eine Klasse zur Seite, mit deren Hilfe man während des Debuggen von Code sich Informationen anzeigen lassen kann, ohne die Infolog-Klasse missbrauchen zu müssen.


 
 
 

Dynamics AX: Die Aktualisierung muss im Rahmen einer Buchung ausgeführt werden

...heisst nichts anderes, als daß man beim Entwickeln ttsbegin/ttscommit vergessen hat.

Eine nicht ganz glücklich ins Deutsche übersetzte Fehlermeldung ;-)


 
 
 

Zertifizierungsprüfung Microsoft Dynamics AX 4.0 Development Introduction

01.09.2008In eigener Sache

Congratulations! You have passed this Microsoft Dynamics exam.

Nach rund 5 Jahren Entwicklung im Umfeld von Microsoft Dynamics AX habe ich heute meine erste Zertifizierungsprüfung bestanden. Leider nur mit 98%, d.h. eine der 75 Fragen habe ich falsch beantwortet. Trotzdem: Juchu ;-)

Weitere Prüfungen werden folgen, schließlich wäre ich irgendwann gerne Microsoft Certified Business Management Solutions Specialist for Microsoft Dynamics AX.


 
 
 

Dynamics AX: Illegal property value

Wenn man in Dynamics AX versucht die Eigenschaft AllowDuplicates eines Tabellen-Indexes von No auf Yes zu ändern, kann folgende Fehlermeldung auftreten:

Illegal property value

In diesem Fall ist vermutlich der betroffene Index als PrimaryIndex oder ClusteredIndex der Tabelle eingetragen. Eigentlich auch logisch :-)


 
 
 

Dynamics AX: Container Quicktipp

Container sind ja was feines, und aus diesem Grund verwende ich sie immer wieder gerne beim Programmieren unter Dynamics AX. Durch einen Blog-Beitrag bei SysDictCoder bin ich auf einen kleinen Trick gestossen, der mir in Zukunft etwas Tipp-Arbeit ersparen wird.

Und zwar habe ich bisher Container immer ähnlich wie im folgenden befüllt:

container fieldCon = conNull();
;
fieldCon = conIns(fieldCon, conLen(fieldCon)+1, "accountNum");
fieldCon = conIns(fieldCon, conLen(fieldCon)+1, "name");
fieldCon = conIns(fieldCon, conLen(fieldCon)+1, "zipcode");
fieldCon = conIns(fieldCon, conLen(fieldCon)+1, "countryregionid");
fieldCon = conIns(fieldCon, conLen(fieldCon)+1, "county");

Wesentlich rascher ist die folgende Schreibweise:

container fieldConFast = conNull();
;
fieldConFast += "accountNum";
fieldConFast += "name";
fieldConFast += "zipcode";
fieldConFast += "countryregionid";
fieldConFast += "county";

SysDictCoder geht in seinem Artikel etwas mehr ins Detail, deshalb meine Empfehlung dort mal vorbeizuschauen.


 
 
 

Dynamics AX: SalesTable2LineField

In der Auftragserfassung gibt es im Auftragskopf Felder, die, wenn sie aktualisiert werden, entweder vollautomatisch bzw. nach Rückfrage beim Benutzer in den Auftragszeilen ebenfalls aktualisiert werden. Welche Felder das sind kann in den Debitorenparametern, Register Aktualisierungen über die Schaltfläche Auftragspositionen aktualisieren eingesehen werden. Dort kann auch parametriert werden, wie sich Dynamics AX bei der Aktualisierung dieser Felder verhalten soll.

Debitorenparameter - Auftragspositionen aktualisieren

Um nun ein weiteres Feld in diese Logik mitaufzunehmen bedarf es einiger Schritte. Im folgenden demonstriere ich die notwendigen Änderungen anhand des neuen Feldes DevReceiptDateRequested (abgeleitet vom EDT DevSalesReceiptDateRequested):

 

  • Neues Feld in Tabelle Salestable und Salesline anlegen
  • Das neue Feld in der Salestable in die Fieldgroup HeaderToLineUpdate integrieren
  • In der Klasse SalesTable2LineField die Methode lineUpdateDescription um das neue Feld erweitern (einfach die Logik eines bestehenden Feldes abschreiben)
  • In der Klasse SalesLineType die Methode initFromSalesTable um das neue Feld erweitern (einfach die Logik eines bestehenden Feldes abschreiben)
  • In der Klasse AxSalesline eine neue Methode wie folgt erstellen
    protected boolean isDevReceiptDateRequestedSet()
    {
         return this.isFieldSet(fieldNum(SalesLine, DevReceiptDateRequested)) ||
                this.AxSalesTable().isFieldModified(fieldNum(SalesTable, DevReceiptDateRequested));
    }
  • In der Klasse AxSalesline eine weitere Methode wie folgt erstellen
    public DevSalesReceiptDateRequested DevReceiptDateRequested(DevSalesReceiptDateRequested _DevReceiptDateRequested = dateNull())
    {
       if (!prmisdefault(_DevReceiptDateRequested))
       {
           this.setField(fieldNum(SalesLine, DevReceiptDateRequested), _DevReceiptDateRequested);
       }
     
       return SalesLine.DevReceiptDateRequested;
    }
  • In der Klasse AxSalesline eine dritte neue Methode wie folgt erstellen
    protected void setDevReceiptDateRequested()
    {
       if (this.isMethodExecuted(funcName(), fieldNum(SalesLine, DevReceiptDateRequested)))
       {
           return;
       }
       if (this.isDevReceiptDateRequestedSet())
       {
           this.DevReceiptDateRequested(this.AxSalesTable().DevReceiptDateRequested());
       }
    }
  • In der Klasse AxSalesLine muss nun die Methode setTableFields um den Aufruf der zuvor angelegten Methode setDevReceiptDateRequested erweitert werden
  • In der Klasse AxSalesTable eine neue Methode wie folgt anlegen
    protected void setDevReceiptDateRequested()
    {
        ;
        if (this.isMethodExecuted(funcName(), fieldNum(SalesTable, DevReceiptDateRequested)))
        {
            return;
        }
    }
  • In der Klasse AxSalesTable eine weitere Methode wie folgt anlegen
    public DevSalesReceiptDateRequested DevReceiptDateRequested(DevSalesReceiptDateRequested _DevReceiptDateRequested = dateNull())
    {
        ;
        if (!prmisdefault(_DevReceiptDateRequested))
        {
            this.setField(fieldNum(SalesTable, DevReceiptDateRequested), _DevReceiptDateRequested);
        }
    
        return salesTable.DevReceiptDateRequested;
    }
  • In der Klasse AxSalesTable muss nun die Methode setTableFields um den Aufruf der zuvor angelegten Methode setDevReceiptDateRequested erweitert werden
  • Nun muß noch folgender Code einmalig ausgeführt werden (z.B. per Job) um das neue Feld in die Aktualisierungslogik einzubinden
    SalesTable2LineParameters salesTable2LineParameters;
    ;
    ttsbegin;
    salesTable2LineParameters.clear();
    salesTable2LineParameters.initValue();
    salesTable2LineParameters.fieldId           = fieldNum(SalesTable, DevReceiptDateRequested);
    salesTable2LineParameters.table2LineUpdate  = Table2LineUpdate::Prompt;
    salesTable2LineParameters.insert();
    ttscommit;

Übrigens, die gleiche Logik gibt es natürlich auch einkaufsseitig. Die obige Abfolge und die Codebeispiele wurden unter AX3 entwickelt.

Update vom 28.07.2010: In Dynamics AX 2009 funktioniert die beschriebene Lösung genauso. Lediglich beim auszuführenden Job hat sich der Datentyp des Feldes table2LineUpdate geändert.


 
 
 

Dynamics AX: Methode des "Callers" aufrufen

Immer wieder besteht die Notwendigkeit, ein Formular über ein anderes zu öffnen und aus diesem heraus Methoden des Aufrufers aufzurufen.

Einfaches Beispiel: Ich öffne aus der Auftragsmaske (Salestable) irgendein anderes Formular (über einen MenuItemButton) und möchte nun beim Schliessen dieses Formulares eine Methode in der Salestable-Maske aufrufen.
Um dies zu realisieren muß ich einfach in der Close-Methode des Subformulars folgenden Code einbinden. myMethod steht dabei für die aufzurufende Methode des Salestable-Formulares.

Achtung: IntelliSense funtioniert in diesem Fall nicht (außer ich möchte eine Methode aufrufen, die im FormRun-Objekt enthalten ist).

if (element.args() && element.args().caller())
{
    if (element.args().caller().name() == formStr(Salestable))
    {
        element.args().caller().myMethod();
    }
}

 
 
Seiten 1 2 3 » 

 

 
 
 
Beiträge des aktuellen Monats
April 2008
MoDiMiDoFrSaSo
 123456
78910111213
14151617181920
21222324252627
282930 
 
© 2006-2025 Heinz Schweda | Impressum | Kontakt | English version | Mobile Version
Diese Webseite verwendet Cookies, um Benutzern einen besseren Service anzubieten. Wenn Sie weiterhin auf der Seite bleiben, stimmen Sie der Verwendung von Cookies zu.  Mehr dazu