除了MongoDB的剖析器,可以很方便地找到慢查询。但是要知道这些查询为什么慢会更麻烦一些,因为这个过程中可能还要求有点“侦查工作”。正如前面所说,慢查询的原因是多种多样的。走运的话,加个索引就能解决慢查询。在更复杂的情况下,可能不得不重新安排索引、重建数据模型、或者升级硬件。
最简单的情况里,问题的根本原因是缺少索引,索引不当或者查询不理想。通过剖析器定位了慢查询后,可以在慢查询上使用explain()来确认原因。explain的使用方式是在执行语句后面加上explain。3.x版本后的explain用法,explain(true)代表allPlansExecution mode,传入false代表queryPlanner mode.使用.explain(true).modeName可以显示具体的操作模式。
db.stock.find({}).sort({close:-1}).limit(1).explain(true)执行结果如下