Additional Blogs by SAP
cancel
Showing results for 
Search instead for 
Did you mean: 
Former Member
0 Kudos
1,550
What is Query Optimization?  It is based on internal storage and aggregation data that is collected by the OLAP processor. There are things that are different in each system like aggregates, size of tables, and variable values. That's why the OLAP processor might generate different run schedules.  How optimization works:  This optimization has nothing to do with CBO or database statistics. Every time a query is started, BW checks if optimization would be beneficial. If yes, it sets the OPT_OCCURS flag in table RSRREPDIR. Once the query is generated the flag is reset. Using SE16 on table RSRREPDIR you can quickly findout which queries should be regenerated (OPT_OCCURS = X). The timestamp tells you when the last check was performed.  Generally, as reports are run, they are almost always flagged to be optimized again.   Executing and scheduling optimization:  To optimize a query individually, go to RSRT and hit Generate Report. To schedule query optimization in mass on a periodic basis, you can schedule this by cube using program RSR_GEN_DIRECT_ALL_QUERIES. In your process chain, you can parallelize the optimization by running each cube in parallel. To enhance scheduling such that you can choose the OPT_OCCURS=X (only optimize queries that have been executed since last optimization), you can enhance this program by creating a Z Program. In most cases, this will speed up the optimization.   Why use Query Optimization?  When working with this mass generation, a few observations have been made. In general, I have seen anywhere between a 5% and a 250% increase in performance. Every time a query is run, the flag OPT_OCCURS marks the query “not-optimized”. This does not actually mean the performance has degenerated. In actuality, tests show that queries generally run ok for 2 to 5 days before re-generation is needed. This is due to how quickly your model changes. This means that if your data grows a lot, aggregates change, stats change, etc… The optimization changes the code of the query to optimize it on how the system currently looks. If this changes frequently, optimization may need to occur more often. If it changes in-frequently, then scheduling this every few weeks may not be a bad idea. The following enhancement allows you to only regenerate queries that have been run since being last optimized. To do this, you would copy program RSR_GEN_DIRECT_ALL_QUERIES to a Z Program, and then add the 2 lines of code below. If you wanted, you could also enhance this program to add the query technical name as an input field. That way, you could choose individual queries that you wanted to generate.   * input-fields SELECT-OPTIONS:  i_icube      FOR rsrrepdir-infocube,                  i_OBjST      FOR rsrrepdir-OBJSTAT,                  i_READMD     FOR rsrrepdir-READMODE,                  i_AUTHOR     FOR rsrrepdir-AUTHOR,                  i_CACHMD     FOR rsrrepdir-CACHEMODE, *------------------------------------------------------- *START - Add this line                  i_OPTOCC     FOR rsrrepdir-OPT_OCCURS, *END *-------------------------------------------------------                  i_PERSMD     FOR rsrrepdir-PERSISTMODE.  START-OF-SELECTION.     SELECT * FROM rsrrepdir INTO TABLE l_t_rsrrepdir                           WHERE objvers = 'A'                           AND   infocube     IN i_icube                           AND   objstat      IN i_OBjST                           AND   READMODE     IN i_READMD                           AND   AUTHOR       IN i_AUTHOR                           AND   CACHEMODE    IN i_CACHMD                           AND   PERSISTMODE  IN i_PERSMD *------------------------------------------------------- *START - Add this line                           AND   OPT_OCCURS   IN i_OPTOCC *END *-------------------------------------------------------                           ORDER BY INFOCUBE compid.   Benefits of query Optimization:  One problem that you may notice when having queries with 2 very large complex structures is that it takes a while for the variable screen to come up. Running query optimization generally solves this problem. Also, query optimization is a must after applying any notes or support packs that effect OLAP. I leave it to you to test it out and see the performance improvements you get!  Related OSS Notes: 755330, 771498, 659901, and 814911
22 Comments