i've got a sql-query, executed against non-ax-tables ( partially at least ) from x++ via odbc. the sql-query-execution-plan suggests to add an index to the referring ax-table, eg:
CREATE NONCLUSTERED INDEX [] ON [ ([field1]) INCLUDE ([several fields])
i remember it wasn't a good idea to create any of those indices via management-studio on the ax-tables, but how to create such an index via ax? should the fields in the include block simply be added in the field-list?
another inde开发者_JAVA技巧x-hint was an easier one:
CREATE NONCLUSTERED INDEX [] ON [] ([field1],[field2])
but even creating this index in ax on the regarding table and the named field - the query analyzer still suggests to create this index.
viewing the create-statement for this index in sql managmement-studio, the dataAreaID-column is included ( automatically )....
any hints? thanks in advance!
answer to comments:
it is a sql-query executed from x++. the tables used are partially ax-tables and partially not. the only index which seems missing is one on the ax-table.
i didn't want to discuss index optimizations in general, but just ask if there's a possibility to add an index in ax, representing the "include..." part of the first "create-index-query"!
i surely know about the fact to regard the DAID-column in queries outside ax - i was just surprised that the management-studio criticizes a missing index for fieldA + fieldB, when in fact this index is already existing ( regarding the DAID automatically ).
thanks 4 reply!
The fact that it suggest fieldA+fieldB indicates, that you do not have a DataAreaId selection on a query.
AX always adds DataAreaId as the first field in an index.
Also you can analyze you SQL query, to get an execution plan by putting the SQL in the Execution plan dialog in Administration/Inquiries/Database statements ...
This will indicate what indices are in use.
I have had a similirar concern, and here is an article that shows how to create Indexes with Includes on AX tables.
Essentially you create the SQL index from X++ code:
public static server void createSQLIndexPointTransferHeader()
Connection connection = new Connection();
Statemetn statement = connection.createStatement();
SqlStatementExecutionPermission sqlStatementExecutionPermission;
str createIndexSQL;
;
//Create the index
createIndexSQL = @"IF EXISTS (SELECT * FROM sys.Indexes WHERE onject_id=(N'[dbo].[LIO_POINTTRANSHEADER]) AND name=N'I_NEWWINECLUBCARD_IDX')
DROP INDEX [I_NEWWINECLUBCARD_IDX] ON [dbo].[LIO_POINTTRANSHEADER] WITH (ONLINE=OFF)
CREATE NONCLUSTEREDINDEX INDEX [I_NEWWINECLUBCARD_IDX] ON [dbo].[LIO_POINTTRANSHEADER]
(
[WINECLUBCARDID]
)
INCLUDE ([FIELD1],[FIELD2]/*OTHER FIELDS*/) WITH (PAD_INDEX=OFF /* OTHER WITH OPTIONS*/);
sqlStatementExecutionPermission = new SqlStatementPermission(createIndexSQL);
sqlStatementExecutionPermission .assert;
//BP Deviation Documented
statement.executeUpdate(createIndexSQL);
CodeAccessPermission::revertAssert();
... the actual Index text to be updated to your specfic requirements.
http://daxdilip.blogspot.com/2011/05/tip-how-to-avoid-overriding-of-sql.html
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论