Dynamics AX Blog - Dynamics AX 2012 - Finanzdimensionen - Dynamics AX 2012 - sysoperation-framework - Seite 3
In Dynamics AX 2012 hat sich die Handhabung von Finanzdimensionen stark verändert. Und zwar sowohl auf der Oberfläche als auch das dahinterliegende Datenmodell. Wo früher noch ein Feld - meist mit dem Namen Dimension - vom Typ Array in einer Tabelle zu finden war, so findet man nun stattdessen ein von RecId abgeleitetes Feld namens DefaultDimension (o.ä.).
In dieser Serie möchte ich speziell auf diese Änderungen eingehen und das eine oder andere Stück Code präsentieren.
RSS-Feed dieser Blogserie
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. |
|
|
|
|
|
|
Der folgende Job demonstriert, wie man sich die Werte einer Finanzdimension - im Beispiel Department - per X++ ausgeben lassen kann.