- Reference >
- Operators >
- Query Modifiers >
- $explain
$explain¶
- 
$explain¶
- The - $explainoperator provides information on the query plan. It returns a document that describes the process and indexes used to return the query. This may provide useful insight when attempting to optimize a query. For details on the output, see cursor.explain().- You can specify the - $explainoperator in either of the following forms:- You also can specify - $explainthrough the- explain()method in the- mongoshell:- $explainruns the actual query to determine the result. Although there are some differences between running the query with- $explainand running without, generally, the performance will be similar between the two. So, if the query is slow, the- $explainoperation is also slow.- Additionally, the - $explainoperation reevaluates a set of candidate query plans, which may cause the- $explainoperation to perform differently than a normal query. As a result, these operations generally provide an accurate account of how MongoDB would perform the query, but do not reflect the length of these queries.- To determine the performance of a particular index, you can use - hint()and in conjunction with- explain(), as in the following example:- When you run - explain()with- hint(), the query optimizer does not reevaluate the query plans.- Note - In some situations, the - explain()operation may differ from the actual query plan used by MongoDB in a normal query.- The - explain()operation evaluates the set of query plans and reports on the winning plan for the query. In normal operations the query optimizer caches winning query plans and uses them for similar related queries in the future. As a result MongoDB may sometimes select query plans from the cache that are different from the plan displayed using- explain().- See also - explain()
- Optimization Strategies for MongoDB page for information regarding optimization strategies.
- Analyze Performance of Database Operations tutorial for information regarding the database profile.
- Current Operation Reporting