Editar

Partilhar via


Query throttling

If a query creates a disproportional load on the database storing Microsoft Dataverse data, it can starve the database of resources and negatively impact performance of all data operations. When this happens, Dataverse starts throttling that query to allow all other scenarios to perform normally.

The primary way in which query throttling is different from Service protection API limits is query throttling targets a query that causes a performance degradation while leaving the rest of the traffic unaffected. If the throttled query originates from a non-interactive application, throttling is likely to not be noticeable for end-users. If the query originates from an interactive application, it affects users that exercise that particular scenario.

Query throttling behavior

Throttling can manifest in three ways:

  • A delay is introduced before each execution of the query, making the scenario that uses it slower
  • Some fraction of attempts to execute the query are failing with any of the following errors:
Error code
Hex code
Name Message
-2147187388
0x80048544
DataEngineQueryThrottling This query cannot be executed because it conflicts with query throttling.
-2147187132
0x80048644
DataEngineLeadingWildcardQueryThrottling This query cannot be executed because it conflicts with Query Throttling; the query uses a leading wildcard value in a filter condition, which will cause the query to be throttled more aggressively.
-2147186876
0x80048744
DataEngineComputedColumnQueryThrottling This query cannot be executed because it conflicts with Query Throttling; the query uses a computed column in a filter condition, which will cause the query to be throttled more aggressively.
-2147186875
0x80048745
DataEnginePerformanceValidationIssuesQueryThrottling This query cannot be executed because it conflicts with Query Throttling; the query has performance validation issues ({0}), which will cause the query to be throttled more aggressively.

Dataverse error for query throttling caused by anti-patterns

Dataverse heavily throttles queries that use known query anti-patterns when they're identified as a risk to the health of the environment to help prevent outages.

When a query fails due to throttling and the query is using one of the anti-patterns, Dataverse returns the following unique error to help identify which anti-patterns the query is using:

Name: DataEnginePerformanceValidationIssuesQueryThrottling
Code: 0x80048745
Number: -2147186875
Message: This query cannot be executed because it conflicts with Query Throttling; the query has performance validation issues ({0}), which will cause the query to be throttled more aggressively. Please refer to this document: https://go.microsoft.com/fwlink/?linkid=2162952

The {0} part of the exception message lists the anti-pattern that the query is using. If there are multiple anti-patterns used by the query, they're comma separated. For example, if a query is filtering on a large text column and is also selecting a large number of columns, the exception message contains the string PerformanceLargeColumnSearch,LargeAmountOfAttributes. The following table lists the anti-patterns with links to explanations:

Anti-pattern identifier Explanation link
PerformanceLeadingWildCard Avoid leading wild cards in filter conditions
PerformanceLargeColumnSearch Avoid using conditions on large text columns
OrderOnEnumAttribute Avoid ordering by choice columns
OrderOnPropertiesFromJoinedTables Avoid ordering by columns in related tables
LargeAmountOfAttributes Minimize the number of selected columns
LargeAmountOfLogicalAttributes Minimize the number of selected logical columns
FilteringOnCalculatedColumns Avoid using formula or calculated columns in filter conditions

Note

If a query contains either the PerformanceLeadingWildCard or the FilteringOnCalculatedColumns anti-pattern, a different Dataverse error is thrown. Queries that use the PerformanceLeadingWildCard anti-pattern throw the DataEngineLeadingWildcardQueryThrottling error mentioned on this page, and queries that use the FilteringOnCalculatedColumns anti-pattern throw the DataEngineComputedColumnQueryThrottling error mentioned on this page.

The DataEngineLeadingWildcardQueryThrottling and DataEngineComputedColumnQueryThrottling errors predate the DataEnginePerformanceValidationIssuesQueryThrottling error; DataEngineLeadingWildcardQueryThrottling and DataEngineComputedColumnQueryThrottling continue to be thrown to maintain backward compatibility.

Common causes

Most of the situations when query throttling is necessary fall into one of these two broad categories:

  • Some query in a common interactive scenario is inefficient and requires a lot of database resources for each execution

    • Common examples are a saved query used in a grid or a query executed by a plug-in
  • An automated operation executes a query at a high rate that consumes a lot of database resources in aggregate even if each execution is less expensive

    • A common example is data integration that moves a large amount of data into or out of Dataverse

How to avoid query throttling

Query throttling depends on the query and the scenario where it runs but there are some common guidelines:

  • For slow low-frequency queries, typically used in interactive applications, the query structure needs to be changed to make it more efficient

  • For non-interactive applications the common ways to reduce the database load are:

    • When using ExecuteMultiple (or another batching mechanism), reduce the size of the batch
    • If the application is multi-threaded, reduce the number of concurrent threads
    • If you aren't using batching or concurrent requests, add a delay between requests to reduce the request rate

See also

Query anti-patterns
Optimize performance using FetchXml
Optimize performance using QueryExpression
Service protection API limits