एक्सप्रेसजेएस - डेटाबेस
हम अनुरोध प्राप्त करते रहते हैं, लेकिन उन्हें कहीं भी संग्रहीत नहीं करते हैं। डेटा स्टोर करने के लिए हमें एक डेटाबेस की आवश्यकता होती है। इसके लिए, हम 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 का पता लगाने के लिए, एपीआई डॉक्स पढ़ें ।