La función Query.prototype.geometry() se utiliza para especificar una condición de $geometría. La geometría se puede proporcionar en una array que se pasa como parámetro.
Sintaxis:
Query.prototype.geometry()
Parámetros: esta función tiene un parámetro de objeto que debe contener una propiedad de tipo de tipo string y una propiedad de coordenadas de tipo array.
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
Base de datos: La base de datos de muestra utilizada aquí se muestra a continuación.
Después de eso, puede simplemente crear una carpeta y agregar un archivo, por ejemplo, index.js como 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 } }); var query = User.find() var polyA = [[[ 11, 21 ], [ 11, 41 ], [ 31, 41 ], [ 31, 21 ]]] query.where('loc').within() .geometry({ type: 'Polygon', coordinates: polyA }) console.log(query._conditions.loc)
Ejecute el archivo index.js usando el siguiente comando:
node index.js
Producción:
{ '$geoWithin': { '$geometry': { type: 'Polygon', coordinates: [Array] } } }
Ejemplo 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.find() var polyA = [[[ 15, 25 ], [ 15, 45 ], [ 35, 45 ], [ 35, 25 ]]] query.where('loc').within() .geometry({ type: 'Polygon', coordinates: polyA }) console.log(query._conditions.loc) app.listen(3000, function(error ) { if(error) console.log(error) console.log("Server listening on PORT 3000") });
Ejecute el archivo index.js usando el siguiente comando:
node index.js
Producción:
Server listening on PORT 3000 { '$geoWithin': { '$geometry': { type: 'Polygon', coordinates: [Array] } } }
Referencia:
https://mongoosejs.com/docs/api/query.html#query_Query-geometry
Publicación traducida automáticamente
Artículo escrito por gouravhammad y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA