Dynamics AX Blog - Dynamics AX 2012 - Seite 32

RSS-Feed dieser Version
AX 2012: Kontostruktur eines Hauptkontos ermitteln
11.05.2012Microsoft Dynamics AX (Axapta)
Möchte man für das Hauptkonto einer Position einer Allgemeinen Erfassung ermitteln, kann man dies mit Hilfe des nachstehenden Codes tun. static void getAccountStructureFromLedgerDimension(Args _args) { ledgerJournalTrans ledgerJournalTrans; select ledgerJournalTrans where ledgerJournalTrans.JournalNum == '000151_010'; info(DimensionStorage::getAccountStructureFromLedgerDimension(ledgerJournalTrans.LedgerDimension).Name); } |
AX 2012: Standardfinanzdimension eines Datensatzes auslesen und ausgeben
09.05.2012Microsoft Dynamics AX (Axapta)
Im folgenden Job werden die eingetragenen Standardfinanzdimensionen eines Datensatzes - im konkreten Fall die eines bestimmten Debitoren - ausgegeben. static void getDimensionsFromDefaultDimension(Args _args) { DimensionAttributeValueSet dimensionAttributeValueSet; DimensionAttributeValueSetItem dimensionAttributeValueSetItem; DimensionAttributeValue dimensionAttributeValue; DimensionAttribute dimensionAttribute; Common dimensionValueEntity; dimensionAttributeValueSet = DimensionAttributeValueSet::find(CustTable::find('9101').DefaultDimension); // Find all of the 'value set items' linked against the 'value set' while select dimensionAttributeValueSetItem where dimensionAttributeValueSetItem.DimensionAttributeValueSet == dimensionAttributeValueSet.RecId { // Find the dimension 'value' (DimensionAttributeValue) that the set item points to. dimensionAttributeValue = DimensionAttributeValue::find(dimensionAttributeValueSetItem.DimensionAttributeValue); // Find the underlying attribute. dimensionAttribute = DimensionAttribute::find(dimensionAttributeValue.DimensionAttribute); // Use the helper class to obtain a reference to the underlying entity (can be anything) dimensionValueEntity = DimensionDefaultingControllerBase::findBackingEntityInstance( curext(), dimensionAttribute, dimensionAttributeValue.EntityInstance); info(strFmt("%1: %2", dimensionAttribute.Name, dimensionAttributeValue.getValue())); } } |
AX 2012: Dimensionen einer Position einer Allgemeines Erfassung per X++ auslesen
09.05.2012Microsoft Dynamics AX (Axapta)
|
AX 2012: Datensätze mit einer bestimmten Dimension ausgeben
08.05.2012Microsoft Dynamics AX (Axapta)
Der folgende Job listet alle Debitoren auf, bei welchen in der Dimension CustomerGroup der Wert 80 eingetragen ist. Der interessante Teil des Jobs ist die Methode addDimensionAttributeRange der Klasse SysQuery, da diese sich um das Verknüpfen der benötigten Datenquellen kümmert. static void getRecords4DimensionValue(Args _args)
{ Query query; QueryBuildDataSource queryBuildDataSource; QueryBuildRange queryBuildRange; QueryRun queryRun; CustTable custTable; query = new Query(); queryBuildDataSource = query.addDataSource(tableNum(CustTable)); queryBuildRange = SysQuery::addDimensionAttributeRange( query, queryBuildDataSource.name(), "DefaultDimension", DimensionComponent::DimensionAttribute, queryValue("80"), "CustomerGroup"); queryRun = new QueryRun(query); while(queryRun.next()) { custTable = queryRun.get(tableNum(CustTable)); info(custTable.name()); } } Die Klasse SysQuery stellt übrigens zahlreiche weitere ähnliche Funktionen zur Verfügung, um mit Dimensionswerten zu arbeiten. |
AX 2012: ID, LegacyID und Origin
08.05.2012Microsoft Dynamics AX (Axapta)
Ein Must-Read zu dem Thema ist freilich: http://blogs.msdn.com/b/mfp/archive/2011/07/11/the-solution-to-the-element-id-problem.aspx
| ||||||
Formular als Dialog verwenden
06.04.2012Microsoft Dynamics AX (Axapta)
Im AOT befinden sich einige tutorial-Objekte, die dem Entwickler dabei helfen können, die eine oder andere Anforderung zu lösen. Eine dieser Klassen ist die Klasse tutorial_RunbaseForm, die erklärt wie man statt einem Dialog ein eigens erstelltes Formular als Dialog verwendet. Auf Basis dieses Turorials habe ich in Dynamics AX 2012 eine Anforderung wie folgt gelöst: |
|
|
|
|
|
|
Der folgende Job demonstriert, wie man sich die Werte einer Finanzdimension - im Beispiel Department - per X++ ausgeben lassen kann.