BW Query Guidelines
BW Query Guidelines
BW Query Guidelines
Business Warehouse
Query Guidelines
Brenda McCool
UK-BW Reporting Group
Hannes Lombard &
Miki Lam
LSI-Certified SAP BW consultants
BW Query Design and Performance:
Specific Query Design Guidelines...................................................................................... 2
Variables/Parameters/Prompts........................................................................................ 2
Key Figures..................................................................................................................... 2
Characteristics:................................................................................................................ 3
General Query Design Considerations for Improved Performance.................................... 4
Frequently asked questions ................................................................................................. 5
Why set Suppress Zeroes to Active? .............................................................................. 5
If I have a complex calculation, how do I get it on the InfoCube?................................. 5
What can I do if I have a query that runs a long time or if the query continues to run
without stopping (hung-up / infinite loop / …)?............................................................. 5
What can I do if the field(s) I need is not in an InfoProvider? ....................................... 5
Can I use other tools (Crystal / Brio / WebFOCUS / …) along with or instead of BEx
to get to SAP data?.......................................................................................................... 5
What will happen if I close the BEx window while a query is running?........................ 5
Where are the naming standards? ................................................................................... 6
Since navigational attributes incur performance penalties, when is it acceptable to use
them and what should I do if I need one? ....................................................................... 6
Glossary .............................................................................................................................. 7
Some of the Glossary definitions have been taken from the SAP Library
http://help.sap.com/saphelp_erp2004/helpdata/en/88/3c1640d4642402e10000000a1550b0/frameset.htm
Page 1 9/22/2005
Specific Query Design Guidelines
• Report names/titles should have the first letter of each word capitalized except for pronouns
(ie. and, a, for, the, etc.)
• Suppress zeroes should be selected/set to Active in the query properties.
• Limit the use of structures except in cases where the same large grouping of key figures or
characteristics is used across many reports. This helps to minimize development and rework
when making changes
• Follow naming standards for all objects created (i.e. queries, variables, structures, calculated
key figures, etc.).
Variables/Parameters/Prompts
• Use existing variables across all InfoCubes for uniformity to users
• Group mandatory/required variables at top of variable screen where possible.
• Group similar variables together.
• A time period should generally be a mandatory/required variable.
Key Figures
• Negative numbers should be displayed within parentheses - i.e. (12) is a negative twelve.
• In SAP R/3 tables, postings to revenue (GL Accounts 400000-499999) and liability (GL
Accounts 200000-299999) accounts are made with CREDIT posting keys, and the amounts
are displayed as MINUS amounts. In a report however, you would not want to display them
as MINUS, so for REVENUE and LIABILITIES the suggestion is to change the symbol.
REVENUE and LIABILITIES key figures from the data models (FM & SL), for new restricted /
calculated key figures created in future using REVENUE and LIABILITIES key figures as
base. The report writer should of course also make sure that all formulas using these key
figures are still accurate. (example: is +50 and -100 still -50 or does it become +150.....).
Page 2 9/22/2005
Characteristics:
• The time period characteristic should be included in every report if available.
• Avoid multiple characteristics in rows/columns to reduce details in initial query (more details
in initial query = more result set = more unlikely to find aggregates)
• Properties of each characteristic used in a query
o Display as “Key and text” – where available
o Display of Results / Suppress Results Rows “With Only One Value”
Page 3 9/22/2005
General Query Design Considerations for Improved Performance
• Minimize the amount of information that is returned by the query. The less information that is
returned from the query, generally the faster it can be transferred to the end user.
• Limit the number of key figures that are returned from the database for queries.
• Using calculated key figures that require numerous key figures to calculate the result will
degrade the performance of the queries. If the calculated key figure is used often and
requires mores that 2-3 key figures to calculate consider storing it directly in the InfoProvider.
• Only show required key figures. For example, if a formula is displayed do not show all the
individual key figures that comprise the formula unless necessary.
• Suppressing the display of key figures may improve network load as less information is
passed to the user but the key figures are still retrieved from the database impacting overall
query performance.
• Design queries to prevent a large number of rows from being returned (greater than 500).
This may be accomplished by using mandatory variables to filter data or create exception
reports to return only the data of interest.
• Limit the number of free characteristics available in the report in order to ensure that large
amounts of data cannot be requested. This also assists in avoiding database joins involving
a large number of tables. Each characteristic that is displayed in the result set generally adds
one table join to the generated SQL for the query.
• Avoid complex queries that offer everything for every user. Create multiple queries to meet
the requirements and/or use the report/report interface to link reports together at different
levels of detail.
• Design queries to be specific so that aggregates can be built to improve performance.
Numerous drilldown possibilities make it difficult to predict and resolve performance issues
since endless possibilities may need to be analyzed.
• If a tabular type (flat) report is required build it using an ODS if available. The database joins
and indexing are much simpler in these cases and can be more easily optimized.
• If you have a choice of building a query from an InfoCube or MultiProvider always choose the
InfoCube. Building a query from a MultiProvider will require additional table joins in order to
satisfy the query.
• Avoid using remote InfoCubes except in the case where there is a small amount of data and
a limited number of users.
• Use Web reporting rather than Business Explorer (BEx) Analyzer. Web reporting reduces the
network overhead when compared to BEx. In addition, Web reports generally offer better
performance than BEx Analyzer queries.
• Minimize the number of restricted key figures (RKF) used in the query. RKF’s result in
additional database processing and complexity in retrieving the query results.
• Instead of putting a restriction on a RKF, try to use a variable. This will cut down on the
query processing time, especially if the user utilizes the personalization feature.
• Minimize the use of characteristics in rows and columns for the initial query view. Include
them as free characteristics that can be included when required. This will tend to bring back
less data because it is more summarized and will likely be able to use an aggregate.
• Use characteristics or navigational attributes rather than hierarchies, especially when the
hierarchies are large with many nodes. If hierarchies are to be used, limit the number of
nodes in the query results by using filters and variables for the hierarchy. The objective
should be to make the entry hierarchy level as deep as possible upon executing the report.
This limits the levels of the hierarchy that must be processed at execution time.
Page 4 9/22/2005
• Use filters as much as possible, especially for large characteristics, to reduce the size of the
query result.
• Minimize conditions and exceptions as much as possible. If they are not always required,
define them as inactive and allow the report user to enable them when required.
• Minimize the number of reusable structures in the query. Due to their complexity they can
impact performance as they are evaluated at query time similar to RKF’s.
• Only use navigational attributes on the report if they are required. It is better to use a
characteristic if available. Even though navigational attributes appear the same to end users,
the way they are accessed via the database incurs a performance penalty for using them due
to the joins it generates.
• If too many complex calculations are being done in queries, it will add considerably to front-
end time. The general rule of thumb is that you don’t want to use more than 10 calculations
in a query, rather move them into the InfoProvider.
Setting Suppress Zeroes to Active in the query properties eliminates the output of an item that
does not have any activity (quantity/amount equals zero); therefore, making the report more
condensed and readable.
InfoCubes are managed by a Data Warehouse Manager. You will need to send a request for
change to BWRequests@email.uky.edu . Identify the InfoCube along with the calculation that is
needed and the suggested name for the calculated key figure. Make the name as descriptive as
possible within 9 characters.
What can I do if I have a query that runs a long time or if the query continues to
run without stopping (hung-up / infinite loop / …)?
Send email to BWRequests@email.uky.edu. Identify the InfoArea, InfoProvider and the query.
Depending on the problem, you may want to consider adding more filters or narrowing the range
of data selected for your query.
Send email to BWRequests@email.uky.edu. Identify the InfoProvider and the field(s) in question.
Can I use other tools (Crystal / Brio / WebFOCUS / …) along with or instead of BEx
to get to SAP data?
At this time, there are no other tools connected to the SAP data.
What will happen if I close the BEx window while a query is running?
Processing stops.
Page 5 9/22/2005
Where are the naming standards?
The naming standards are in a separate document. Go to the Reporting Home Page
(https://reporting.uky.edu) and click on the Business Warehouse link.
You will need a navigational attribute when you identify an attribute assigned to an InfoObject that
you need to filter on or drill-down on and it is not already an InfoObject.
Page 6 9/22/2005
Glossary
Attributes (Master Data Attributes): Are not stored in an InfoCube. They are
joined to the master data.
Conditions: By defining a condition, you have the option of analyzing the query
results in more detail. You can analyze combinations of characteristics using
ranked lists, thereby displaying your ten best/worst vendors by sales.
Filter: A filter has a limiting effect on the data selected. When defining the filter,
you select characteristic values from one or more characteristics or from a key
figure. All of the InfoProvider data is aggregated using the filter selection of the
query.
Example: A hierarchy for fund centers that are combined in fund center groups.
Page 7 9/22/2005
Hierarchies can be loaded into the BW system or created in the BW system for
hierarchy basic characteristics. They can be used across InfoProviders.
There are two types of InfoProviders. One type includes objects that contain
physical data. These are known as data targets, such as InfoCubes, ODS
objects, and InfoObjects (characteristics with attributes, texts, or hierarchies).
The other type includes objects that display no physical data storage, such as
InfoSets, RemoteCubes, SAP RemoteCubes, and MultiProviders.
Key Figures: Type of InfoObject. Numeric fields; like number of items on hand,
account credit amount & account debit amount.
Page 8 9/22/2005
Master Data: Static data (data that rarely changes) describing characteristics.
Example: An employee’s master data can be Birthdate, Home Address, Home
Phone, Social Security Number, and Ethnicity.
The MultiProvider itself contains no data; its data comes exclusively from the
InfoProviders on which it is based (collated using a join-union operation). You
can assemble a MultiProvider from different combinations of InfoProviders.
ODS: Operational Data Store is an object that stores consolidated and cleansed
transaction data on a document level
Report to Report Interface: The report-report interface allows you the flexibility
to call a jump target (receiver) online from a BW query (sender) within or outside
of the Business Information Warehouse. Jump targets that have been assigned
to a BW query can be selected in BEx Web applications and in the BEx Analyzer.
You access them from the context menu under the Goto function.
Local Structures: Structures that have not been saved as reusable that
can only be used in one query.
Page 9 9/22/2005