Query.prototype .$where() especifica una función o expresión de JavaScript para pasar al sistema de consulta de MongoDB. Usando esto, donde la condición se puede personalizar de acuerdo con la necesidad del usuario.
Sintaxis:
Query.prototype.$where()
Parámetros: esta función tiene un parámetro js, es decir, string o función de JavaScript.
Valor de retorno: esta función devuelve el objeto de consulta.
Instalación de mangosta:
npm install mongoose
Después de instalar el módulo mongoose, puede verificar su versión mongoose en el símbolo del sistema usando el comando.
npm mongoose --version
Después de eso, puede simplemente crear una carpeta y agregar un archivo, por ejemplo, index.js como se muestra a continuación.
Base de datos: La base de datos de muestra utilizada aquí se muestra a continuación:
Estructura del proyecto: La estructura del proyecto se verá así:
Ejemplo 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) } });
Ejecute el archivo index.js usando el siguiente comando:
node index.js
Producción:
[ { _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 } ]
Ejemplo 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) } });
Ejecute el archivo index.js usando el siguiente comando:
node index.js
Producción:
[]
Referencia:
https://mongoosejs.com/docs/api/query.html#query_Query-$where
Publicación traducida automáticamente
Artículo escrito por gouravhammad y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA