📌  相关文章
📜  Query.prototype.$where() 如何在Mongoose中工作?

📅  最后修改于: 2022-05-13 01:56:42.133000             🧑  作者: Mango

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