mongod源代码Find的QueryPlanner::plan评分最高计划put到cache流程分析
db.user.find({age:28})命令QueryPlanner::plan()只会生成一个执行计划,_pickBestPlan直接选择这个计划。db.user.find({age:28}).sort({wages:1})命令QueryPlanner::plan()会生成两个执行计划,_pickBestPlan循环执行两个计划,根据返回结果等参数进行评分,选择评分高的计划执行。如果db.u