Koa.js - डेटाबेस

हम अनुरोध प्राप्त कर रहे हैं, लेकिन उन्हें कहीं भी संग्रहीत नहीं कर रहे हैं। डेटा स्टोर करने के लिए हमें एक डेटाबेस की आवश्यकता होती है। हम एक प्रसिद्ध NoSQL डेटाबेस का उपयोग करेंगेMongoDB। Mongo के बारे में स्थापित करने और पढ़ने के लिए, इस लिंक पर जाएं।

कोआ के साथ मोंगो का उपयोग करने के लिए, हमें नोड के लिए एक क्लाइंट एपीआई की आवश्यकता है। वहाँ हमारे लिए कई विकल्प हैं, हालांकि इस ट्यूटोरियल हम करने के लिए रह सकते हैं के लिए कर रहे हैं नेवला । Mongoose का उपयोग किया जाता हैdocument modelingMongoDB के लिए नोड में। दस्तावेज़ मॉडलिंग का मतलब है कि, हम एक निर्माण करेंगेModel (ज्यादा पसंद है class दस्तावेज़-उन्मुख प्रोग्रामिंग में), और फिर हम उत्पादन करेंगे documents इस मॉडल का उपयोग करना (जैसे हम बनाते हैं documents of a classOOP में)। हमारे सभी प्रसंस्करण इन "दस्तावेजों" पर किए जाएंगे, फिर अंत में, हम इन दस्तावेजों को अपने डेटाबेस में लिखेंगे।

मानगो की स्थापना

अब जब हमने Mongo को स्थापित किया है, तो हम mongoose स्थापित करते हैं, उसी तरह हम अपने अन्य नोड पैकेजों को स्थापित कर रहे हैं।

$ npm install --save mongoose

इससे पहले कि हम आम का उपयोग करना शुरू करें, हमें मोंगो शेल का उपयोग करके एक डेटाबेस बनाना होगा। एक नया डेटाबेस बनाने के लिए, अपना टर्मिनल खोलें और "मोंगो" डालें। एक मैंगो शेल शुरू होगा, निम्नलिखित दर्ज करें।

use my_db

आपके लिए एक नया डेटाबेस बनाया जाएगा। जब भी आप मैंगो खोल खोलते हैं, तो यह "परीक्षण" डीबी के लिए डिफ़ॉल्ट होगा और आपको ऊपर के समान कमांड का उपयोग करके अपने डेटाबेस में बदलना होगा।

Mongoose का उपयोग करने के लिए, हमें अपनी app.js फ़ाइल में इसकी आवश्यकता होगी और फिर mongodb पर चलने वाली mongod सेवा से कनेक्ट करें: // 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);

अब हमारा ऐप हमारे डेटाबेस से जुड़ा हुआ है, चलो एक नया मॉडल बनाते हैं। यह मॉडल हमारे डेटाबेस में एक संग्रह के रूप में कार्य करेगा। एक नया मॉडल बनाने के लिए, किसी भी मार्ग को परिभाषित करने से पहले, निम्न कोड का उपयोग करें।

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);

उपरोक्त कोड एक व्यक्ति के लिए स्कीमा को परिभाषित करता है और इसका उपयोग एक मॉडल बनाने के लिए किया जाता है Person

सेविंग डॉक्यूमेंट्स

अब हम एक नया html फॉर्म बनाएंगे, जिसमें किसी व्यक्ति का विवरण होगा और उसे हमारे डेटाबेस में सेव किया जाएगा। फ़ॉर्म बनाने के लिए, निम्नलिखित सामग्री के साथ व्यू डायरेक्टरी में person.pug नामक एक नई व्यू फ़ाइल बनाएँ।

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

इस दस्तावेज़ को रेंडर करने के लिए index.js में एक नया प्राप्त मार्ग भी जोड़ें।

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);

लोकलहोस्ट पर जाएं: 3000 / व्यक्ति यह जांचने के लिए कि क्या हमारा फॉर्म सही प्रदर्शित हो रहा है। ध्यान दें कि यह सिर्फ UI है, यह अभी तक काम नहीं कर रहा है। इसी से हमारा रूप दिखता है।

अब हम '/ व्यक्ति' पर एक पोस्ट रूट हैंडलर को परिभाषित करेंगे जो इस अनुरोध को संभाल लेगा।

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);

उपरोक्त कोड में, यदि हमें कोई खाली फ़ील्ड मिलती है या कोई फ़ील्ड नहीं मिलती है, तो हम एक त्रुटि प्रतिक्रिया भेजेंगे। हालाँकि, यदि हमें एक अच्छी तरह से निर्मित दस्तावेज़ प्राप्त होता है, तो हम एक व्यक्तिगत दस्तावेज़ मॉडल से बनाते हैं और इसे अपने डीबी के उपयोग से बचाते हैंnewPerson.save()समारोह। यह मानस में परिभाषित किया गया है और एक कॉलबैक को तर्क के रूप में स्वीकार करता है। इस कॉलबैक में दो तर्क हैं,error तथा response। यह show_message दृश्य प्रदान करेगा, इसलिए हमें इसे भी बनाने की आवश्यकता है।

इस मार्ग से प्रतिक्रिया दिखाने के लिए, हमें एक बनाने की भी आवश्यकता होगी show_messageराय। निम्नलिखित कोड के साथ एक नया दृश्य बनाएं।

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!

निम्नलिखित प्रतिक्रिया हमें फॉर्म (show_message.pug) को सफलतापूर्वक सबमिट करने पर प्राप्त होती है।

अब हमारे पास व्यक्तियों को बनाने के लिए एक इंटरफ़ेस है!

पुनः प्राप्त करने के दस्तावेज

दस्तावेज़ प्राप्त करने के लिए मोंगोज़ बहुत सारे कार्य प्रदान करता है, हम उनमें से तीन पर ध्यान केंद्रित करेंगे। ये सभी फ़ंक्शन अंतिम पैरामीटर के रूप में कॉलबैक भी लेते हैं, और फ़ंक्शन को बचाने की तरह, उनके तर्क त्रुटि और प्रतिक्रिया हैं।

तीन कार्य हैं -

Model.find (स्थितियां, कॉलबैक)

इस फ़ंक्शन को ऑब्जेक्ट ऑब्जेक्ट में फ़ील्ड से मेल खाते सभी दस्तावेज़ मिलते हैं। मानगो में इस्तेमाल किए जाने वाले समान ऑपरेटर भी आम में काम करते हैं। उदाहरण के लिए, यह सभी दस्तावेजों को व्यक्तियों के संग्रह से प्राप्त करेगा।

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

यह उन सभी दस्तावेज़ों को प्राप्त करेगा जहाँ फ़ील्ड का नाम "आयुष" है और उम्र 20 है।

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

हम अपनी जरूरत के हिसाब से अपनी जरूरत के मुताबिक प्रक्षेपण भी दे सकते हैं। उदाहरण के लिए, यदि हम केवल चाहते हैंnames लोगों की nationalityहै "भारतीय" , हम का उपयोग करें -

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

Model.findOne (स्थितियां, कॉलबैक)

यह कार्य हमेशा एक एकल, सबसे अधिक प्रासंगिक दस्तावेज़ प्राप्त करता है। इसमें Model.find () के समान सटीक तर्क हैं।

Model.findById (आईडी, कॉलबैक)

यह फ़ंक्शन लेता है _id(प्रथम द्वारा परिभाषित) पहले तर्क के रूप में, एक वैकल्पिक प्रक्षेपण स्ट्रिंग और प्रतिक्रिया को संभालने के लिए एक कॉलबैक। उदाहरण के लिए,

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

सभी लोगों के रिकॉर्ड देखने के लिए एक मार्ग बनाएं।

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);

अद्यतन दस्तावेज़

दस्तावेज़ अद्यतन करने के लिए Mongoose तीन कार्य प्रदान करता है।

Model.update (स्थिति, अपडेट, कॉलबैक)

यह फ़ंक्शन एक शर्त लेता है और ऑब्जेक्ट को इनपुट के रूप में अपडेट करता है और संग्रह में शर्तों से मेल खाने वाले सभी दस्तावेजों में परिवर्तन लागू करता है। उदाहरण के लिए, निम्नलिखित कोड राष्ट्रीयता "अमेरिकी" रखने के लिए सभी व्यक्ति दस्तावेजों को अपडेट करेगा।

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

Model.findOneAndUpdate (स्थिति, अपडेट, कॉलबैक)

जैसा कहता है वैसा ही करता है। क्वेरी के आधार पर एक दस्तावेज़ पाता है और दूसरे तर्क के अनुसार अपडेट करता है। यह अंतिम तर्क के रूप में कॉलबैक भी लेता है। उदाहरण के लिए,

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

Model.findByIdAndUpdate (आईडी, अपडेट, कॉलबैक)

यह फ़ंक्शन अपनी आईडी द्वारा पहचाने गए एकल दस्तावेज़ को अपडेट करता है। उदाहरण के लिए,

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

लोगों को अपडेट करने के लिए एक मार्ग बनाते हैं। यह आईडी के साथ PUT रूट होगा जो पेलोड में पैरामीटर और विवरण के रूप में होगा।

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);

इस मार्ग का परीक्षण करने के लिए, अपने टर्मिनल में निम्नलिखित दर्ज करें (आईडी को अपने बनाए गए लोगों से आईडी के साथ बदलें)।

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

यह उपरोक्त विवरण के साथ मार्ग में प्रदान किए गए आईडी से जुड़े दस्तावेज़ को अपडेट करेगा।

दस्तावेज़ हटाना

हमने कवर किया है Create, Read और Update, अब हम देखेंगे कि दस्तावेज़ों को हटाने के लिए मैंगोज़ का उपयोग कैसे किया जा सकता है। यहां तीन फ़ंक्शन हैं, बिल्कुल अपडेट की तरह।

Model.remove (स्थिति, [कॉलबैक])

यह फ़ंक्शन इनपुट के रूप में एक शर्त वस्तु लेता है और शर्तों से मेल खाते सभी दस्तावेजों को हटा देता है। उदाहरण के लिए, यदि हमें 20 वर्ष की आयु के सभी लोगों को हटाने की आवश्यकता है,

Person.remove({age:20});

Model.findOneAndRemove (स्थिति, [कॉलबैक])

यह कार्य एक हटाता है single, शर्तों वस्तु के अनुसार सबसे प्रासंगिक दस्तावेज़। उदाहरण के लिए,

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

Model.findByIdAndRemove (आईडी, [कॉलबैक])

यह फ़ंक्शन अपनी आईडी द्वारा पहचाने गए एकल दस्तावेज़ को हटा देता है। उदाहरण के लिए,

Person.findByIdAndRemove("507f1f77bcf86cd799439011");

अब अपने डेटाबेस से लोगों को हटाने के लिए एक मार्ग बनाते हैं।

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);

इसका परीक्षण करने के लिए, निम्नलिखित कर्ल कमांड का उपयोग करें -

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

यह नीचे दिए गए संदेश का निर्माण करने वाले आईडी वाले व्यक्ति को हटा देगा। -

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

यह बताता है कि हम MongoDB, mongoose और Koa का उपयोग करके सरल CRUD एप्लिकेशन कैसे बना सकते हैं। आगे मानगो का पता लगाने के लिए, एपीआई डॉक्स पढ़ें ।