Query.prototype.explain() 函數用於設置解釋選項,從而使此查詢返回詳細的執行統計信息而不是實際查詢結果。
用法:
Query.prototype.explain()
參數:該函數有一個可選的詳細參數。返回值:該函數返回查詢對象。
安裝 Mongoose :
npm install mongoose
安裝 mongoose 模塊後,您可以使用命令在命令提示符下檢查您的 mongoose 版本。
npm mongoose --version
現在,創建一個文件夾並添加一個文件,例如 index.js,如下所示。
數據庫:這裏使用的示例數據庫如下所示:
項目結構:項目結構如下所示。
範例1:
index.js
const mongoose = require('mongoose');
// Database connection
mongoose.connect('mongodb://127.0.0.1:27017/geeksforgeeks', {
useNewUrlParser:true,
useCreateIndex:true,
useUnifiedTopology:true
});
// User model
const User = mongoose.model('User', {
name:{ type:String },
age:{ type:Number }
});
var query = User.find({age:5}).explain('queryPlanner')
query.exec(function(err, res){
if(err) console.log(err.message)
else console.log(res)
});
使用以下命令運行index.js文件:
node index.js
輸出:
[ { queryPlanner:{ plannerVersion:1, namespace:'geeksforgeeks.users', indexFilterSet:false, parsedQuery:[Object], queryHash:'3838C5A3', planCacheKey:'38305F3', winningPlan:[Object], rejectedPlans:[] }, executionStats:{ executionSuccess:true, nReturned:1, executionTimeMillis:0, totalKeysExamined:0, totalDocsExamined:4, executionStages:[Object], allPlansExecution:[] }, serverInfo:{ host:'Lenovo530S', port:27017, version:'4.2.0', gitVersion:'a4b751dcf51dd249c58812b390cfd1c0129c30' }, ok:1 } ]
範例2:
index.js
const express = require('express');
const mongoose = require('mongoose');
const app = express()
// Database connection
mongoose.connect('mongodb://127.0.0.1:27017/geeksforgeeks', {
useNewUrlParser:true,
useCreateIndex:true,
useUnifiedTopology:true
});
// User model
const User = mongoose.model('User', {
name:{ type:String },
age:{ type:Number }
});
var query = User.find({age:5}).explain('allPlansExecution')
query.exec(function(err, res){
if(err) console.log(err.message)
else console.log(res)
});
app.listen(3000, function(error ) {
if(error) console.log(error)
console.log("Server listening on PORT 3000")
});
使用以下命令運行index.js文件:
node index.js
輸出:
Server listening on PORT 3000 [ { queryPlanner:{ plannerVersion:1, namespace:'geeksforgeeks.users', indexFilterSet:false, parsedQuery:[Object], queryHash:'3838SF3', planCacheKey:'3238C5F3', winningPlan:[Object], rejectedPlans:[] }, executionStats:{ executionSuccess:true, nReturned:1, executionTimeMillis:0, totalKeysExamined:0, totalDocsExamined:4, executionStages:[Object], allPlansExecution:[] }, serverInfo:{ host:'Lenovo530S', port:27017, version:'4.2.0', gitVersion:'a4b751dcf51sd249c5865812b390cfd1c0129c30' }, ok:1 } ]
參考:
https://mongoosejs.com/docs/api/query.html#query_Query-explain
相關用法
- Mongoose Query.prototype.gte()用法及代碼示例
- Mongoose Query.prototype.hint()用法及代碼示例
- Mongoose Query.prototype.mod()用法及代碼示例
- Mongoose Query.prototype.getUpdate()用法及代碼示例
- Mongoose Query.prototype.centerSphere()用法及代碼示例
- Mongoose Query.prototype.exec()用法及代碼示例
- Mongoose Query.prototype.error()用法及代碼示例
- Mongoose Query.prototype.equals()用法及代碼示例
- Mongoose Query.prototype.elemMatch()用法及代碼示例
- Mongoose Query.prototype.distinct()用法及代碼示例
- Mongoose Query.prototype.cursor()用法及代碼示例
- Mongoose Query.prototype.comment()用法及代碼示例
- Mongoose Query.prototype.catch()用法及代碼示例
- Mongoose Query.prototype.collation()用法及代碼示例
- Mongoose Query.prototype.cast()用法及代碼示例
- Mongoose Query.prototype.box()用法及代碼示例
- Mongoose Query.prototype.batchSize()用法及代碼示例
- Mongoose Query.prototype.and()用法及代碼示例
- Mongoose Query.prototype.all()用法及代碼示例
- Mongoose Query.prototype.lt()用法及代碼示例
- Mongoose Query.prototype.lean()用法及代碼示例
- Mongoose Query.prototype.intersects()用法及代碼示例
注:本文由純淨天空篩選整理自gouravhammad大神的英文原創作品 How does Query.prototype.explain() work in Mongoose?。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。