Best Practices for Indexes [AX 2012]
Updated: December 5, 2011
Applies To: Microsoft Dynamics AX 2012 R3, Microsoft Dynamics AX 2012 R2, Microsoft Dynamics AX 2012 Feature Pack, Microsoft Dynamics AX 2012
The basic rules for index design are as follows:
-
Assign a unique index to each table.
-
Add as few indexes as possible and maintain query performance.
-
Strongly consider designating one of the indexes as the cluster index.
An error will be displayed if an index is overlapped by another index, and the other is enabled and doesn't have a configuration key.
An error will also be displayed if an index is created with no fields in it.
The advantages of indexes are as follows:
-
Their use in queries usually results in much better performance.
-
They make it possible to quickly retrieve (fetch) data.
-
They can be used for sorting. A post-fetch-sort operation can be eliminated.
-
Unique indexes guarantee uniquely identifiable records in the database.
The disadvantages of indexes are as follows:
-
They decrease performance on inserts, updates, and deletes.
-
They take up space (this increases with the number of fields used and the length of the fields).
-
Some databases will monocase values in fields that are indexed.
You should only create indexes when they are actually needed.
Take care not to add an index on something that has already been indexed. If you need a more detailed index, you can add fields to an existing index as long as it is not a unique index.
Tip |
|---|
|
It is more time-consuming to change fields at the beginning of an index than at the end of an index. If fields in an index are updated frequently, place these at the end of the index. |
When you use index hints, verify them with performance tests. The optimizer might be able to find a more efficient hint.
The following examples show finding ledger transactions in account number, transaction date order.
Last weeks' (few days) transactions on all the (many) Profit & Loss accounts.
select ledgerTrans
index hint DateIdx
order by accountNum, transDate
where ledgerTrans.accountNum >= '40000'
&& ledgerTrans.accountNum <= '99999'
&& ledgerTrans.transDate >= 26\04\1999
&& ledgerTrans.transDate <= 02\05\1999;
Transactions for the whole year (many dates) on (the few) liquid assets accounts.
select ledgerTrans
index hint ACDate
order by accountNum, transDate
where ledgerTrans.accountNum >= '11100'
&& ledgerTrans.accountNum <= '11190'
&& ledgerTrans.transDate >= 01\07\1999
&& ledgerTrans.transDate <= 30\06\2000;
Announcements: New book: "Inside Microsoft Dynamics AX 2012 R3" now available. Get your copy at the MS Press Store.
Tip