Query.prototype.$where() 如何在Mongoose中工作?
Query.prototype.$where()指定一个 JavaScript函数或表达式以传递给 MongoDB 的查询系统。使用它,可以根据用户的需要定制条件。
句法:
Query.prototype.$where()
参数:该函数有一个参数js,即JavaScript字符串或函数。
返回值:此函数返回 Query 对象。
安装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 }
});
const query = User.find();
query.collection(User.collection);
query.$where(function () {
if (this.age < 100) return true;
else return false;
})
query.where('age').gte(1).exec(function(error, result) {
if (error) {
console.log(error)
} else {
console.log(result)
}
});
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 }
});
const query = User.find();
query.collection(User.collection);
query.$where(function () {
if (this.age < 100) return false;
else return true;
})
query.where('age').gte(1).exec(function(error, result) {
if (error) {
console.log(error)
} else {
console.log(result)
}
});
使用以下命令运行index.js文件:
node index.js
输出:
[
{ _id: 5ebb9129a99bde77b2efb809,
name: 'Gourav', age: 10, __v: 0 },
{ _id: 5ebc3669a99bde77b2efb9ba,
name: 'Lalit', age: 25, __v: 0 },
{ _id: 5ebc367da99bde77b2efb9bf,
name: 'Piyush', age: 5, __v: 0 },
{ _id: 5ebd345f5d2d8a3534b2f391,
name: 'Manish', age: 34, __v: 0 }
]
示例 2:
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 }
});
const query = User.find();
query.collection(User.collection);
query.$where(function () {
if (this.age < 100) return false;
else return true;
})
query.where('age').gte(1).exec(function(error, result) {
if (error) {
console.log(error)
} else {
console.log(result)
}
});
使用以下命令运行index.js文件:
node index.js
输出:
[]
参考:
https://mongoosejs.com/docs/api/query.html#query_Query-$where