Mongoose 查詢 API distinct() 方法用於查找集合中特定字段的不同值並將響應作為數組返回。
用法:
Query.prototype.distinct(field, filter, callback)
參數:它接受如上所述和如下所述的以下參數:
- field:它是一個字符串,用於標識要為其返回不同值的字段。
- filter:它是一個可選的 Mongoose 對象,派生自 Query.prototype.setOptions()。
- callback:它是一個回調函數,接受 2 個參數:error 和 arr。
返回類型:它返回一個 Query 對象作為響應。
創建節點應用程序並安裝 Mongoose:
步驟1:使用以下命令創建節點應用程序:
mkdir folder_name cd folder_name npm init -y touch main.js
步驟 2:完成 Node.js 應用程序後,使用以下命令安裝所需的模塊:
npm install mongoose
示例 1:在此示例中,我們將使用此方法查找集合中字段 “age” 的不同值。
文件名:main.js
Javascript
// Importing the module
const mongoose = require('mongoose')
// Connecting to the database
mongoose.connect('mongodb://localhost:27017/query-helpers',
{
dbName: 'event_db',
useNewUrlParser: true,
useUnifiedTopology: true
}, err => err ? console.log(err)
: console.log('Connected to database'));
const personSchema = new mongoose.Schema({
name: {
type: String,
},
age: {
type: Number,
}
});
const personsArray = [
{
name: 'Luffy',
age: 20
},
{
name: 'Nami',
age: 20,
},
{
name: 'Zoro',
age: 35
}
]
const Person = mongoose.model('Person', personSchema);
(async () => {
await Person.insertMany(personsArray);
const res = await Person.distinct('age');
console.log({ res });
})()
運行應用程序的步驟:從項目的根目錄使用以下命令運行應用程序:
node main.js
輸出:
使用 MongoDB 指南針的數據庫的 GUI 表示:
示例 2:在此示例中,我們將使用此方法查找集合中字段 “name” 的不同值。
文件名:main.js
Javascript
// Importing the module
const mongoose = require('mongoose')
// Connecting to the mongodb
mongoose.connect('mongodb://localhost:27017/query-helpers',
{
dbName: 'event_db',
useNewUrlParser: true,
useUnifiedTopology: true
}, err => err ? console.log(err)
: console.log('Connected to database'));
const personSchema = new mongoose.Schema({
name: {
type: String,
},
age: {
type: Number,
}
});
const personsArray = [
{
name: 'Luffy',
age: 20
},
{
name: 'Nami',
age: 20,
},
{
name: 'Zoro',
age: 35
}
]
const Person = mongoose.model('Person', personSchema);
(async () => {
await Person.insertMany(personsArray);
const res = await Person.distinct('name');
console.log({ res });
})()
運行應用程序的步驟:從項目的根目錄使用以下命令運行應用程序:
node main.js
輸出:
使用 MongoDB 指南針的數據庫的 GUI 表示:
參考: https://mongoosejs.com/docs/api/query.html#query_Query-distinct
相關用法
- Mongoose Query.prototype.distinct()用法及代碼示例
- Mongoose Query.prototype.deleteMany()用法及代碼示例
- Mongoose Query.prototype.deleteOne()用法及代碼示例
- Mongoose Query.prototype.all()用法及代碼示例
- Mongoose Query.prototype.and()用法及代碼示例
- Mongoose Query.prototype.batchSize()用法及代碼示例
- Mongoose Query.prototype.box()用法及代碼示例
- Mongoose Query.prototype.catch()用法及代碼示例
- Mongoose Query.prototype.centerSphere()用法及代碼示例
- Mongoose Query.prototype.circle()用法及代碼示例
- Mongoose Query.prototype.collation()用法及代碼示例
- Mongoose Query.prototype.cursor()用法及代碼示例
- Mongoose Query.prototype.exec()用法及代碼示例
- Mongoose Query.prototype.explain()用法及代碼示例
- Mongoose Query.prototype.geometry()用法及代碼示例
- Mongoose Query.prototype.getOptions()用法及代碼示例
- Mongoose Query.prototype.getPopulatedPaths()用法及代碼示例
- Mongoose Query.prototype.getUpdate()用法及代碼示例
- Mongoose Query.prototype.gt()用法及代碼示例
- Mongoose Query.prototype.gte()用法及代碼示例
- Mongoose Query.prototype.hint()用法及代碼示例
- Mongoose Query.prototype.lean()用法及代碼示例
- Mongoose Query.prototype.limit()用法及代碼示例
- Mongoose Query.prototype.lt()用法及代碼示例
- Mongoose Query.prototype.lte()用法及代碼示例
注:本文由純淨天空篩選整理自dishebhbhayana大神的英文原創作品 Mongoose Query.prototype.distinct() API。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。