Dynamics AX Blog - Seite 20
Produktionsauftrag per Code erstellen
13.07.2014Microsoft Dynamics AX (Axapta)
Mit Hilfe des folgenden Jobs kann man sich per Code einen Produktionsauftrag erstellen. Leider habe ich in Dynamics AX weder eine AX<Table>-Klasse für die Prodtable gefunden (die ich persönlich ja sehr gerne verwende) noch irgendeine andere Klasse mit Hilfe derer man einen Produktionsauftrag erstellen kann. static void createProdTable(Args _args) { ProdQty qty = 10; ItemId itemId = "D0005"; ProdTable prodTable; InventTable inventTable; inventTable = InventTable::find(itemId); prodTable.initValue(); prodTable.initFromInventTable(inventTable); prodTable.ItemId = inventTable.ItemId; prodTable.modifiedField(fieldNum(ProdTable, ItemId)); prodTable.QtySched = qty; prodTable.modifiedField(fieldNum(ProdTable, QtySched)); prodTable.RemainInventPhysical = prodTable.QtySched; prodTable.modifiedField(fieldNum(ProdTable, RemainInventPhysical)); prodTable.initBOMVersion(); prodTable.initRouteVersion(); prodTable.insert(); } |
Ermitteln der reservierten Menge einer Auftragsposition für bestimmte Dimensionen
03.07.2014Microsoft Dynamics AX (Axapta)
Mit Hilfe des folgenden Jobs kann man die reservierte Menge einer Auftragsposition ermitteln. Dabei kann man über einen InventDim-Datensatz jene Dimensionen angeben, für die man die Information benötigt. static void getPhysicalReservedQtyForSalesLine(Args _args)
{ InventTransIdSumSingleStatus inventTransIdSumSingleStatus; SalesLine salesLine; InventMovement inventMovement; InventDim inventDim; InventDimParm inventDimParmCriteria; // Sales order line salesLine = SalesLine::findInventTransId('012431'); inventMovement = InventTrans::findTransId(salesLine.InventTransId).inventMovement(true); // Prepare inventDim-Record: Set Dimensions, which should be used inventDim.clear(); inventDim.InventSiteId = "1"; inventDim.InventLocationId = "12"; inventDim.wmsLocationId = "12"; inventDim = InventDim::findOrCreate(inventDim); inventDimParmCriteria.initFromInventDim(inventDim); inventTransIdSumSingleStatus = InventTransIdSumSingleStatus::newTransOriginIdStatus(InventTransOriginSalesLine::findInventTransOriginId(salesLine.DataAreaId, salesLine.InventTransId), StatusReceipt::None, StatusIssue::ReservPhysical); inventTransIdSumSingleStatus.parmInventDimCriteria(inventDim); inventTransIdSumSingleStatus.parmInventDimParmCriteria(inventDimParmCriteria); info(strFmt("%1", inventTransIdSumSingleStatus.reservPhysical())); } Mit Hilfe der Klasse InventTransIdSumSingleStatus kann man sich auch alle anderen Werte, wie beispielsweise die "In Auftrag" befindliche Menge. Dazu muss der Code nur minimal angepasst werden: |
AX 2012: Anlegen einer Person im Globalen Adressbuch per CodeÜber den nachfolgenden Job kann man in Dynamics AX 2012 per Code eine Person im globalen Adressbuch erstellen. Bitte beachtet, daß der Datensatz mit einem Minimum an Feldern angelegt wird und der sog. Datensatztyp den Wert "Person" aufweist. static void createPerson(Args _args)
{ AxDirPerson axDirPerson; AxDirPersonName axDirPersonName; FirstName firstName = "Firstname"; LastName lastName = "LastName"; axDirPerson = AxDirPerson::construct(); axDirPerson.validateInput(true); axDirPerson.continueOnError(true); // Validate fields without stopping error axDirPerson.parmName(strFmt("%1 %2", firstName, lastName)); axDirPerson.save(); axDirPersonName = new AxDirPersonName(); axDirPersonName.validateInput(true); axDirPersonName.continueOnError(true); // Validate fields without stopping error axDirPersonName.parmFirstName(firstName); axDirPersonName.parmLastName(lastName); axDirPersonName.parmPerson(axDirPerson.dirPerson().RecId); axDirPersonName.parmValidFrom(DateTimeUtil::minValue()); axDirPersonName.parmValidTo(DateTimeUtil::maxValue()); axDirPersonName.save(); } |
AX 2012: Anlegen eines Eintrages im Globalen Adressbuch per CodeÜber den nachfolgenden Job kann man in Dynamics AX 2012 per Code einen Eintrag im globalen Adressbuch erstellen. Bitte beachtet, daß der Datensatz mit einem Minimum an Feldern angelegt wird und der sog. Datensatztyp den Wert "Beliebige" aufweist und dadurch nur bedingt für Unternehmen geeignet ist. Dieser Datensatztyp steuert nämlich u.a. die angezeigten Felder im Kreditorenstamm. Bitte beachtet weiters, daß ebendieser Datensatztyp meines Wissens nach in Dynamics AX nachträglich nicht mehr geändert werden kann. static void createDirPartyTable(Args _args)
{ AxDirPartyTable axDirPartyTable; axDirPartyTable = AxDirPartyTable::construct(); axDirPartyTable.validateInput(true); axDirPartyTable.continueOnError(true); // Validate fields without stopping error axDirPartyTable.parmName( 'Name of Organization'); axDirPartyTable.parmNameAlias( 'Namealias'); axDirPartyTable.parmLanguageId( 'de-at'); axDirPartyTable.parmPartyNumber( '200000'); axDirPartyTable.save(); } |
AX 2012: Anlegen einer Organisation im Globalen Adressbuch per CodeÜber den nachfolgenden Job kann man in Dynamics AX 2012 per Code eine Organisation im globalen Adressbuch erstellen. Bitte beachtet, daß der Datensatz mit einem Minimum an Feldern angelegt wird und der sog. Datensatztyp den Wert "Organisation" aufweist. static void createOrganization(Args _args)
{ AxDirOrganization axDirOrganization; axDirOrganization = AxDirOrganization::construct(); axDirOrganization.validateInput(true); axDirOrganization.continueOnError(true); // Validate fields without stopping error axDirOrganization.parmName( 'Name of Organization'); axDirOrganization.parmNameAlias( 'Namealias'); axDirOrganization.parmLanguageId( 'de-at'); axDirOrganization.parmPartyNumber( '100000'); axDirOrganization.save(); } |
AX 2012: Fehler beim Import eines Model über AXUTIL
13.06.2014Microsoft Dynamics AX (Axapta)
Vor kurzem trat beim Importieren eines Models über AXUTIL folgender Fehler auf:
Ursache war ein Privates Projekt eines Entwicklers, welches vor dem Import manuell entfernt werden musste. Daß es sich bei dem Objekt um ein Privates Projekt handelt, kann man daran sehen, daß in obiger Fehlermeldung ein Benutzerkürzel enthalten ist ("userid01"). |
|
|
|
|
|
|
Dynamics AX stellt ein Framework zur Verfügung, mit dessen Hilfe man Produktionsaufträge in einen bestimmten Status überführen kann. Im Beispiel wird ein Produktionsauftrag vorkalkuliert.
Wenn man mehrere Aufträge gleichzeitig aktualisieren möchte, muss man die Methode ProdMultiCostEstimation.insert() einfach entsprechend oft aufrufen und den jeweiligen Datensatz der ProdTable übergeben.