Koa.js: base de datos

Recibimos las solicitudes, pero no las almacenamos en ningún lugar. Necesitamos una base de datos para almacenar los datos. Usaremos una famosa base de datos NoSQL llamadaMongoDB. Para instalar y leer sobre Mongo, diríjase a este enlace.

Para usar Mongo con Koa, necesitamos una API de cliente para el nodo. Hay varias opciones para nosotros, sin embargo, para este tutorial nos ceñiremos a la mangosta . La mangosta se utiliza paradocument modelingen Node para MongoDB. El modelado de documentos significa que crearemos unModel (muy parecido a un class en programación orientada a documentos), y luego produciremos documents usando este modelo (como creamos documents of a classen OOP). Todo nuestro procesamiento se realizará sobre estos "documentos", luego, finalmente, escribiremos estos documentos en nuestra base de datos.

Configuración de Mongoose

Ahora que tenemos Mongo instalado, instalemos mongoose, de la misma manera que hemos estado instalando nuestros otros paquetes de nodos.

$ npm install --save mongoose

Antes de que comencemos a usar mongoose, tenemos que crear una base de datos usando el shell Mongo. Para crear una nueva base de datos, abra su terminal e ingrese "mongo". Se iniciará un shell de Mongo, ingrese lo siguiente.

use my_db

Se creará una nueva base de datos para usted. Siempre que abra el shell de Mongo, por defecto será "test" db y tendrá que cambiar a su base de datos usando el mismo comando que el anterior.

Para usar mongoose, lo necesitaremos en nuestro archivo app.js y luego nos conectaremos al servicio mongod que se ejecuta en mongodb: // localhost

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

app.use(_.routes());
app.listen(3000);

Ahora que nuestra aplicación está conectada a nuestra base de datos, creemos un nuevo modelo. Este modelo actuará como una colección en nuestra base de datos. Para crear un nuevo modelo, use el siguiente código, antes de definir cualquier ruta.

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

app.use(_.routes());
app.listen(3000);

El código anterior define el esquema para una persona y se usa para crear un modelo de mangosta Person.

Guardar documentos

Ahora crearemos un nuevo formulario html, que obtendrá los detalles de una persona y lo guardará en nuestra base de datos. Para crear el formulario, cree un nuevo archivo de vista llamado person.pug en el directorio de vistas con el siguiente contenido.

html
   head
      title Person
   body
      form(action = "/person", method = "POST")
         div
            label(for = "name") Name: 
            input(name = "name")
         br
         div
            label(for = "age") Age: 
            input(name = "age")
         br
         div
            label(for = "nationality") Nationality: 
            input(name = "nationality")
         br
         button(type = "submit") Create new person

También agregue una nueva ruta get en index.js para renderizar este documento.

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.get('/person', getPerson);

function *getPerson(next){
   this.render('person');
   yield next;
}

app.use(_.routes());
app.listen(3000);

Vaya a localhost: 3000 / person para verificar si nuestro formulario se muestra correctamente. Tenga en cuenta que esto es solo la interfaz de usuario, aún no funciona. Así es como se ve nuestro formulario.

Ahora definiremos un controlador de ruta de publicación en '/ person' que manejará esta solicitud.

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.post('/person', createPerson);

function *createPerson(next){
   var self = this;
   var personInfo = self.request.body; //Get the parsed information
   
   if(!personInfo.name || !personInfo.age || !personInfo.nationality){
      self.render(
         'show_message', {message: "Sorry, you provided wrong info", type: "error"});
   } else {
      var newPerson = new Person({
         name: personInfo.name,
         age: personInfo.age,
         nationality: personInfo.nationality
      });
      yield newPerson.save(function(err, res) {
         if(err)
            self.render('show_message', 
               {message: "Database error", type: "error"});
         else
            self.render('show_message', 
               {message: "New person added", type: "success", person: personInfo});
      });
   }
}

app.use(_.routes());
app.listen(3000);

En el código anterior, si recibimos algún campo vacío o no recibimos ningún campo, enviaremos una respuesta de error. Sin embargo, si recibimos un documento bien formado, creamos un nuevo documento Persona a partir del modelo Persona y lo guardamos en nuestra base de datos usandonewPerson.save()función. Esto se define en mangosta y acepta una devolución de llamada como argumento. Esta devolución de llamada tiene dos argumentos,error y response. Esto representará la vista show_message, por lo que también debemos crearla.

Para mostrar la respuesta de esta ruta, también necesitaremos crear un show_messagever. Cree una nueva vista con el siguiente código.

html
   head
      title Person
   body
      if(type = "error")
         h3(style = "color:red") #{message}
      else
         h3 New person, name: 
            #{person.name}, age: 
            #{person.age} and nationality: 
            #{person.nationality} added!

A continuación se muestra la respuesta que recibimos al enviar con éxito el formulario (show_message.pug).

¡Ahora tenemos una interfaz para crear personas!

Recuperando documentos

Mongoose proporciona muchas funciones para recuperar documentos, nos centraremos en tres de ellos. Todas estas funciones también toman una devolución de llamada como último parámetro y, al igual que la función de guardar, sus argumentos son error y respuesta.

Las tres funciones son:

Model.find (condiciones, devolución de llamada)

Esta función busca todos los documentos que coinciden con los campos del objeto de condiciones. Los mismos operadores utilizados en Mongo también funcionan en mangosta. Por ejemplo, esto buscará todos los documentos de la colección de las personas.

Person.find(function(err, response){
   console.log(response);
});

Esto buscará todos los documentos donde el nombre del campo es "Ayush" y la edad es 20.

Person.find({name: "Ayush", age: 20}, 
   function(err, response){
      console.log(response);
   });

También podemos proporcionar la proyección que necesitamos, es decir, los campos que necesitamos. Por ejemplo, si queremos solo elnames de las personas cuyo nationalityes "indio" , usamos -

Person.find({nationality: "Indian"}, 
   "name", function(err, response) {
      console.log(response);
   });

Model.findOne (condiciones, devolución de llamada)

Esta función siempre obtiene un documento único y más relevante. Tiene exactamente los mismos argumentos que Model.find ().

Model.findById (id, devolución de llamada)

Esta función toma en _id(definido por mongo) como primer argumento, una cadena de proyección opcional y una devolución de llamada para manejar la respuesta. Por ejemplo,

Person.findById("507f1f77bcf86cd799439011", 
   function(err, response){
      console.log(response);
   });

Creemos una ruta para ver todos los registros de personas.

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.get('/people', getPeople);
function *getPeople(next){
   var self = this;
   
   yield Person.find(function(err, response){
      self.body = response;
   });
}
app.use(_.routes());
app.listen(3000);

Actualización de documentos

Mongoose proporciona tres funciones para actualizar documentos.

Model.update (condición, actualizaciones, devolución de llamada)

Esta función toma una condición y actualiza el objeto como entrada y aplica los cambios a todos los documentos que coinciden con las condiciones de la colección. Por ejemplo, el siguiente código actualizará todos los documentos personales para que tengan una nacionalidad "estadounidense".

Person.update({age: 25},
   {nationality: "American"}, 
   function(err, response){
      console.log(response);
   });

Model.findOneAndUpdate (condición, actualizaciones, devolución de llamada)

Hace exactamente lo que dice. Busca un documento basado en la consulta y lo actualiza de acuerdo con el segundo argumento. También toma una devolución de llamada como último argumento. Por ejemplo,

Person.findOneAndUpdate({name: "Ayush"}, 
   {age: 40}, 
   function(err, response){
      console.log(response);
   });

Model.findByIdAndUpdate (identificación, actualizaciones, devolución de llamada)

Esta función actualiza un solo documento identificado por su id. Por ejemplo,

Person.findByIdAndUpdate("507f1f77bcf86cd799439011", 
   {name: "James"}, 
   function(err, response){
      console.log(response);
   });

Creemos una ruta para actualizar a la gente. Esta será una ruta PUT con la identificación como parámetro y detalles en la carga útil.

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();
var mongoose = require('mongoose');

mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.put('/people/:id', updatePerson);

function *updatePerson() {
   var self = this;
   yield Person.findByIdAndUpdate(self.params.id, 
      {$set: {self.request.body}}, function(err, response){
      
      if(err) {
         self.body = {
            message: "Error in updating person with id " + self.params.id};
      } else {
         self.body = response;
      }
   });
}

app.use(_.routes());
app.listen(3000);

Para probar esta ruta, ingrese lo siguiente en su terminal (reemplace la identificación con una identificación de las personas creadas).

curl -X PUT --data "name = James&age = 20&nationality = American" https://localhost:3000/people/507f1f77bcf86cd799439011

Esto actualizará el documento asociado con la identificación proporcionada en la ruta con los detalles anteriores.

Eliminar documentos

Nosotros hemos cubierto Creatar Read y Update, ahora veremos cómo se puede usar la mangosta para eliminar documentos. Aquí hay tres funciones, exactamente como actualizar.

Model.remove (condición, [devolución de llamada])

Esta función toma un objeto de condición como entrada y elimina todos los documentos que cumplen las condiciones. Por ejemplo, si necesitamos eliminar a todas las personas de 20 años,

Person.remove({age:20});

Model.findOneAndRemove (condición, [devolución de llamada])

Esta función elimina un single, documento más relevante según condiciones objeto. Por ejemplo,

Person.findOneAndRemove({name: "Ayush"});

Model.findByIdAndRemove (id, [devolución de llamada])

Esta función elimina un solo documento identificado por su id. Por ejemplo,

Person.findByIdAndRemove("507f1f77bcf86cd799439011");

Ahora creemos una ruta para eliminar personas de nuestra base de datos.

var koa = require('koa');
var _ = require('koa-router')();
var app = koa();

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
   name: String,
   age: Number,
   nationality: String
});

var Person = mongoose.model("Person", personSchema);

_.delete('/people/:id', deletePerson);
function *deletePerson(next){
   var self = this;
   yield Person.findByIdAndRemove(self.params.id, function(err, response){
      if(err) {
         self.body = {message: "Error in deleting record id " + self.params.id};
      } else {
         self.body = {message: "Person with id " + self.params.id + " removed."};
      }
   });
}

app.use(_.routes());
app.listen(3000);

Para probar esto, use el siguiente comando curl:

curl -X DELETE https://localhost:3000/people/507f1f77bcf86cd799439011

Esto eliminará a la persona con la identificación dada y producirá el siguiente mensaje. -

{message: "Person with id 507f1f77bcf86cd799439011 removed."}

Esto resume cómo podemos crear aplicaciones CRUD simples usando MongoDB, mongoose y Koa. Para explorar más a fondo la mangosta, lea los documentos de la API.