PouchDB - การจำลองแบบ

คุณสมบัติที่สำคัญที่สุดอย่างหนึ่งของ PouchDB คือการจำลองแบบกล่าวคือคุณสามารถทำสำเนาฐานข้อมูลได้ คุณสามารถจำลองอินสแตนซ์ PouchDB ที่เก็บไว้ในเครื่องหรืออินสแตนซ์ CouchDB ที่จัดเก็บจากระยะไกล

ไวยากรณ์

ต่อไปนี้เป็นไวยากรณ์ของการจำลองฐานข้อมูลใน PouchDB นี่คือสำเนาของไฟล์source databaseคือเป้าหมาย ด้วยวิธีนี้คุณสามารถส่งผ่านตำแหน่งของฐานข้อมูลต้นทางและปลายทางได้โดยตรงในรูปแบบ String หรือคุณสามารถส่งผ่านอ็อบเจ็กต์ที่เป็นตัวแทนได้

PouchDB.replicate(source, target, [options])

ทั้งซอร์สและเป้าหมายอาจเป็นอินสแตนซ์ PouchDB หรืออินสแตนซ์ CouchDB ก็ได้

การจำลอง LocalDB เป็น CouchDB

สมมติว่ามีฐานข้อมูลที่มีชื่อ sample_database ใน PouchDB และประกอบด้วยเอกสาร 3 ชุด doc1, doc2 และ doc3 ซึ่งมีเนื้อหาดังที่แสดงด้านล่าง

doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'} 
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'} 
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}

ต่อไปนี้เป็นตัวอย่างที่สร้างสำเนาของฐานข้อมูลที่ชื่อ sample_database ที่จัดเก็บไว้ใน CouchDB

//Requiring the package 
var PouchDB = require('PouchDB');

var localdb = 'sample_database';

//Creating remote database object 
var remotedb = 'http://localhost:5984/sample_database';

//Replicating a local database to Remote 
PouchDB.replicate(localDB, remoteDB); 
console.log ("Database replicated successfully");

บันทึกรหัสด้านบนในไฟล์ที่มีชื่อ Replication_example.js. เปิดพรอมต์คำสั่งและเรียกใช้ไฟล์ JavaScript โดยใช้node ดังแสดงด้านล่าง

C:\PouchDB_Examples >node Replication_example.js

สิ่งนี้สร้างสำเนาของฐานข้อมูลชื่อ sample_database ในอินสแตนซ์ CouchDB และแสดงข้อความบนคอนโซลดังที่แสดงด้านล่าง

Database replicated successfully

คุณสามารถตรวจสอบว่าฐานข้อมูลถูกจำลองแบบในอินสแตนซ์ CouchDB ของคุณหรือไม่โดยคลิกที่ลิงค์ต่อไปนี้ http://127.0.0.1:5984/_utils/index.html.

เมื่อคลิกคุณจะเห็นรายการฐานข้อมูลใน CouchDB ของคุณ คุณยังสามารถสังเกตได้ว่าสำเนาของฐานข้อมูลsample_database ถูกสร้างขึ้นที่นี่

หากคุณเลือกฐานข้อมูลจำลองคุณสามารถดูเนื้อหาดังที่แสดงด้านล่าง

การจำลอง CouchDB เป็น PouchDB

สมมติว่ามีฐานข้อมูลที่มีชื่อ Remote_Database ใน CouchDB ประกอบด้วยเอกสาร 3 ชุด ได้แก่ doc1, doc2 และ doc3 ซึ่งมีเนื้อหาดังที่แสดงด้านล่าง

doc1 = {_id: '001', name: 'Geeta', age: 25, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Zara Ali', age: 24, Designation: 'Manager'}
doc3 = {_id: '003', name: 'Mary', age: 23, Designation: 'Admin'}

ต่อไปนี้เป็นตัวอย่างที่สร้างสำเนาของฐานข้อมูลที่ชื่อ Remote_Database ที่เก็บไว้ใน CouchDB ในที่จัดเก็บในตัวเครื่อง

//Requiring the package
var PouchDB = require('PouchDB');

var localdb = 'sample_database';

var remotedb = 'http://localhost:5984/sample_database1';

//Replicating a local database to Remote
PouchDB.replicate(remotedb, localdb);
console.log("Database replicated successfully");

บันทึกรหัสด้านบนในไฟล์ที่มีชื่อ Replication_example2.js. เปิดพรอมต์คำสั่งและเรียกใช้ไฟล์ JavaScript โดยใช้node ดังแสดงด้านล่าง

C:\PouchDB_Examples >node Replication_example2.js

สิ่งนี้จะสร้างสำเนาของฐานข้อมูลที่มีชื่อว่า remote_database ในอินสแตนซ์ PouchDB และแสดงข้อความบนคอนโซลดังที่แสดงด้านล่าง

Database replicated successfully

คุณสามารถตรวจสอบได้ว่าฐานข้อมูลถูกจำลองแบบในอินสแตนซ์ Pouch ของคุณหรือไม่โดยเรียกใช้รหัสต่อไปนี้

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('remote_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true, attachments: true}, function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

หากฐานข้อมูลถูกจำลองแบบในการรันโค้ดข้างต้นคุณจะได้รับเนื้อหาของฐานข้อมูลที่จำลองแบบดังที่แสดงด้านล่าง

[ 
   { 
      id: '001', 
      key: '001', 
      value: { rev: '1-23cf3767e32a682c247053b16caecedb' }, 
      doc: { 
         name: 'Geeta', 
         age: 25, 
         Designation: 'Programmer', 
         _id: '001',
         _rev: '1-23cf3767e32a682c247053b16caecedb' 
      } 
   }, 
   { 
      id: '002', 
      key: '002', 
      value: { rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' }, 
      doc: { 
         name: 'Zara Ali', 
         age: 24, 
         Designation: 'Manager', 
         _id: '002',
         _rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' 
      } 
   }, 
   { 
      id: '003', 
      key: '003', 
      value: { rev: '1-c4cce025dbd30d21e40882d41842d5a4' }, 
      doc: { 
         name: 'Mary', 
         age: 23, 
         Designation: 'Admin', 
         _id: '003', 
         _rev: '1-c4cce025dbd30d21e40882d41842d5a4' 
      } 
   } 
]