Query.prototype.distinct() 如何在Mongoose中工作?
Query.prototype.distinct()函数声明或执行 distinct() 操作。如果我们传递一个回调,那么查询就会执行。
句法:
Query.prototype.distinct()
参数:此函数具有三个可选参数,即。字段、过滤器和回调函数。
返回值:此函数返回查询对象。
安装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.distinct('age');
query.exec(function(error,result) {
if(error) console.log(error)
else console.log(result)
})
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.distinct('name');
query.exec(function(error,result) {
if(error) console.log(error)
else console.log(result)
})
app.listen(3000, function(error ) {
if(error) console.log(error)
console.log("Server listening on PORT 3000")
});
运行程序的步骤:
项目结构将如下所示:
使用以下命令运行index.js文件:
node index.js
输出:
[ 10, 25, 5, 34 ]
示例 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.distinct('name');
query.exec(function(error,result) {
if(error) console.log(error)
else console.log(result)
})
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
[ 'Gourav', 'Lalit', 'Piyush', 'Manish' ]
参考: https://mongoosejs.com/docs/api/query.html#query_Query-distinct