Koa.js - ฐานข้อมูล
เราได้รับคำขอ แต่ไม่ได้จัดเก็บไว้ที่ใด เราจำเป็นต้องมีฐานข้อมูลเพื่อจัดเก็บข้อมูล เราจะใช้ฐานข้อมูล NoSQL ที่มีชื่อเสียงชื่อMongoDB. หากต้องการติดตั้งและอ่านเกี่ยวกับ Mongo ให้ไปที่ลิงค์นี้
ในการใช้ Mongo กับ Koa เราจำเป็นต้องมีไคลเอนต์ API สำหรับโหนด มีหลายตัวเลือกสำหรับเรามี แต่สำหรับการกวดวิชานี้เราจะยึดติดอยู่กับพังพอน พังพอนใช้สำหรับdocument modelingในโหนดสำหรับ MongoDB การสร้างแบบจำลองเอกสารหมายความว่าเราจะสร้างไฟล์Model (เหมือนก class ในการเขียนโปรแกรมเชิงเอกสาร) จากนั้นเราจะผลิต documents โดยใช้ Model นี้ (เหมือนที่เราสร้าง documents of a classใน OOP) การประมวลผลทั้งหมดของเราจะดำเนินการใน "เอกสาร" เหล่านี้จากนั้นสุดท้ายเราจะเขียนเอกสารเหล่านี้ในฐานข้อมูลของเรา
การตั้งค่าพังพอน
ตอนนี้เราติดตั้ง Mongo แล้วให้เราติดตั้งพังพอนแบบเดียวกับที่เราติดตั้งแพ็คเกจโหนดอื่น ๆ
$ npm install --save mongoose
ก่อนที่เราจะเริ่มใช้พังพอนเราต้องสร้างฐานข้อมูลโดยใช้เปลือก Mongo ในการสร้างฐานข้อมูลใหม่ให้เปิดเทอร์มินัลของคุณแล้วป้อน "mongo" เปลือก Mongo จะเริ่มขึ้นให้ป้อนสิ่งต่อไปนี้
use my_db
ฐานข้อมูลใหม่จะถูกสร้างขึ้นสำหรับคุณ เมื่อใดก็ตามที่คุณเปิด Mongo shell ค่าเริ่มต้นจะเป็น "test" db และคุณจะต้องเปลี่ยนเป็นฐานข้อมูลของคุณโดยใช้คำสั่งเดียวกับด้านบน
ในการใช้พังพอนเราจะต้องใช้มันในไฟล์ app.js ของเราจากนั้นเชื่อมต่อกับบริการ mongod ที่ทำงานบน 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);
ตอนนี้แอพของเราเชื่อมต่อกับฐานข้อมูลของเราแล้วเรามาสร้าง Model ใหม่กันเถอะ โมเดลนี้จะทำหน้าที่รวบรวมในฐานข้อมูลของเรา ในการสร้างโมเดลใหม่ให้ใช้รหัสต่อไปนี้ก่อนกำหนดเส้นทางใด ๆ
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 ในไดเร็กทอรี views ที่มีเนื้อหาต่อไปนี้
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);
ไปที่ localhost: 3000 / คนเพื่อตรวจสอบว่าแบบฟอร์มของเราแสดงถูกต้องหรือไม่ โปรดทราบว่านี่เป็นเพียง UI เท่านั้นยังใช้งานไม่ได้ นี่คือลักษณะของแบบฟอร์มของเรา
ตอนนี้เราจะกำหนดตัวจัดการเส้นทางการโพสต์ที่ "/ person" ซึ่งจะจัดการคำขอนี้
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 จากแบบจำลองบุคคลและบันทึกลงในฐานข้อมูลของเราโดยใช้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 (เงื่อนไขการโทรกลับ)
ฟังก์ชันนี้ค้นหาเอกสารทั้งหมดที่ตรงกับฟิลด์ในออบเจ็กต์เงื่อนไข ตัวดำเนินการเดียวกันที่ใช้ใน Mongo ยังทำงานในพังพอน ตัวอย่างเช่นจะดึงเอกสารทั้งหมดจากคอลเล็กชันของบุคคล
Person.find(function(err, response){
console.log(response);
});
การดำเนินการนี้จะดึงเอกสารทั้งหมดที่มีชื่อช่อง "Ayush" และอายุ 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 โทรกลับ)
ฟังก์ชันนี้ใช้เวลาในไฟล์ _id(กำหนดโดย mongo) เป็นอาร์กิวเมนต์แรกสตริงการฉายภาพที่เป็นทางเลือกและการเรียกกลับเพื่อจัดการการตอบสนอง ตัวอย่างเช่น,
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);
การอัปเดตเอกสาร
พังพอนมีฟังก์ชันสามอย่างในการอัปเดตเอกสาร
Model.update (เงื่อนไขการอัปเดตการติดต่อกลับ)
ฟังก์ชันนี้รับเงื่อนไขและอัปเดตอ็อบเจ็กต์เป็นอินพุตและใช้การเปลี่ยนแปลงกับเอกสารทั้งหมดที่ตรงกับเงื่อนไขในคอลเล็กชัน ตัวอย่างเช่นรหัสต่อไปนี้จะอัปเดตเอกสาร Person ทั้งหมดให้มีสัญชาติ "อเมริกัน"
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 (id, อัปเดต, โทรกลับ)
ฟังก์ชันนี้จะอัพเดตเอกสารเดียวที่ระบุโดย id ตัวอย่างเช่น,
Person.findByIdAndUpdate("507f1f77bcf86cd799439011",
{name: "James"},
function(err, response){
console.log(response);
});
มาสร้างเส้นทางเพื่ออัพเดทผู้คนกันเถอะ นี่จะเป็นเส้นทาง PUT โดยมี id เป็นพารามิเตอร์และรายละเอียดใน payload
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);
ในการทดสอบเส้นทางนี้ให้ป้อนข้อมูลต่อไปนี้ในเทอร์มินัลของคุณ (แทนที่ id ด้วย id จากบุคคลที่คุณสร้างขึ้น)
curl -X PUT --data "name = James&age = 20&nationality = American" https://localhost:3000/people/507f1f77bcf86cd799439011
การดำเนินการนี้จะอัปเดตเอกสารที่เกี่ยวข้องกับ id ที่ระบุในเส้นทางพร้อมรายละเอียดข้างต้น
การลบเอกสาร
เราได้ครอบคลุม Create, Read และ Update ตอนนี้เราจะมาดูกันว่าพังพอนสามารถใช้เพื่อลบเอกสารได้อย่างไร มีสามฟังก์ชั่นที่นี่เหมือนกับการอัปเดต
Model.remove (เงื่อนไข [โทรกลับ])
ฟังก์ชั่นนี้รับวัตถุเงื่อนไขเป็นอินพุตและลบเอกสารทั้งหมดที่ตรงกับเงื่อนไข ตัวอย่างเช่นหากเราต้องการเอาคนอายุ 20 ออกทั้งหมด
Person.remove({age:20});
Model.findOneAndRemove (เงื่อนไข [โทรกลับ])
ฟังก์ชันนี้จะลบไฟล์ singleเอกสารที่เกี่ยวข้องมากที่สุดตามวัตถุเงื่อนไข ตัวอย่างเช่น,
Person.findOneAndRemove({name: "Ayush"});
Model.findByIdAndRemove (id, [โทรกลับ])
ฟังก์ชันนี้จะลบเอกสารเดียวที่ระบุโดย id ตัวอย่างเช่น,
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 ต่อไปนี้ -
curl -X DELETE https://localhost:3000/people/507f1f77bcf86cd799439011
การดำเนินการนี้จะลบบุคคลที่มีรหัสที่ระบุซึ่งสร้างข้อความต่อไปนี้ -
{message: "Person with id 507f1f77bcf86cd799439011 removed."}
สิ่งนี้สรุปถึงวิธีที่เราสามารถสร้างแอปพลิเคชัน CRUD อย่างง่ายโดยใช้ MongoDB, พังพอนและ Koa หากต้องการสำรวจพังพอนเพิ่มเติมโปรดอ่านเอกสาร API