एक्सप्रेसजेएस - डेटाबेस

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

Mongo के बारे में स्थापित करने और पढ़ने के लिए, इस लिंक का अनुसरण करें।

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

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

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

npm install --save mongoose

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

use my_db

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

Mongoose का उपयोग करने के लिए, हमें इसकी आवश्यकता होगी index.js फ़ाइल और फिर से कनेक्ट करें mongodb सेवा चल रही है mongodb://localhost

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

उपरोक्त कोड एक व्यक्ति के लिए स्कीमा को परिभाषित करता है और इसका उपयोग एक Mongoose Mode बनाने के लिए किया जाता है 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

इसके अलावा एक जोड़ें new get route में index.js इस दस्तावेज़ को प्रस्तुत करने के लिए -

app.get('/person', function(req, res){
   res.render('person');
});

के लिए जाओ "localhost:3000/person"यह जांचने के लिए कि क्या फॉर्म सही आउटपुट प्रदर्शित कर रहा है। ध्यान दें कि यह सिर्फ UI है, यह अभी काम नहीं कर रहा है। निम्न स्क्रीनशॉट दिखाता है कि फॉर्म कैसे प्रदर्शित होता है -

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

app.post('/person', function(req, res){
   var personInfo = req.body; //Get the parsed information
   
   if(!personInfo.name || !personInfo.age || !personInfo.nationality){
      res.render('show_message', {
         message: "Sorry, you provided worng info", type: "error"});
   } else {
      var newPerson = new Person({
         name: personInfo.name,
         age: personInfo.age,
         nationality: personInfo.nationality
      });
		
      newPerson.save(function(err, Person){
         if(err)
            res.render('show_message', {message: "Database error", type: "error"});
         else
            res.render('show_message', {
               message: "New person added", type: "success", person: personInfo});
      });
   }
});

उपरोक्त कोड में, यदि हमें कोई खाली फ़ील्ड मिलती है या कोई फ़ील्ड नहीं मिलती है, तो हम एक त्रुटि प्रतिक्रिया भेजेंगे। लेकिन अगर हम एक अच्छी तरह से गठित दस्तावेज़ प्राप्त करते हैं, तो हम एक बनाते हैंnewPerson व्यक्ति मॉडल से दस्तावेज़ और इसका उपयोग करके हमारे DB में सहेजें newPerson.save()समारोह। यह मानगो में परिभाषित किया गया है और एक कॉलबैक को तर्क के रूप में स्वीकार करता है। इस कॉलबैक में 2 तर्क हैं - त्रुटि और प्रतिक्रिया। इन तर्कों को प्रस्तुत करना होगा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!

हम सफलतापूर्वक सबमिट करने पर निम्नलिखित प्रतिक्रिया प्राप्त करेंगे form(show_message.pug) -

अब हमारे पास बनाने के लिए एक इंटरफ़ेस है persons

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

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

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

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

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

यह व्यक्ति के संग्रह से सभी दस्तावेजों को प्राप्त करेगा।

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

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

हम अपनी जरूरत के अनुसार प्रक्षेपण भी प्रदान कर सकते हैं, अर्थात हमें जिन क्षेत्रों की आवश्यकता है। उदाहरण के लिए, यदि हम केवल चाहते हैं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 express = require('express');
var app = express();

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.get('/people', function(req, res){
   Person.find(function(err, response){
      res.json(response);
   });
});

app.listen(3000);

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

दस्तावेज़ अद्यतन करने के लिए Mongoose 3 फ़ंक्शन प्रदान करता है। कार्यों का वर्णन नीचे दिया गया है -

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 express = require('express');
var app = express();

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.put('/people/:id', function(req, res){
   Person.findByIdAndUpdate(req.params.id, req.body, function(err, response){
      if(err) res.json({message: "Error in updating person with id " + req.params.id});
      res.json(response);
   });
});

app.listen(3000);

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

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

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

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

हमने कवर किया है Create, Read तथा Update, अब हम देखेंगे कि कैसे Mongoose का उपयोग किया जा सकता है Deleteदस्तावेजों। हमारे यहां 3 कार्य हैं, बिल्कुल अपडेट की तरह।

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

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

Person.remove({age:20});

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

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

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

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

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

Person.findByIdAndRemove("507f1f77bcf86cd799439011");

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

var express = require('express');
var app = express();

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.delete('/people/:id', function(req, res){
   Person.findByIdAndRemove(req.params.id, function(err, response){
      if(err) res.json({message: "Error in deleting record id " + req.params.id});
      else res.json({message: "Person with id " + req.params.id + " removed."});
   });
});

app.listen(3000);

आउटपुट की जाँच करने के लिए, निम्नलिखित कर्ल कमांड का उपयोग करें -

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

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

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

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