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 एप्लिकेशन कैसे बना सकते हैं। आगे मानगो का पता लगाने के लिए, एपीआई डॉक्स पढ़ें ।