- PouchDB 教程
- PouchDB - 首页
- PouchDB - 概述
- PouchDB - 环境
- PouchDB - 创建数据库
- PouchDB - 数据库信息
- PouchDB - 删除数据库
- PouchDB - 创建文档
- PouchDB - 读取文档
- PouchDB - 更新文档
- PouchDB - 删除文档
- PouchDB - 创建批处理
- PouchDB - 获取批处理
- PouchDB - 更新批处理
- PouchDB - 删除批处理
- PouchDB - 添加附件
- PouchDB - 检索附件
- PouchDB - 删除附件
- PouchDB - 复制
- PouchDB - 同步
- PouchDB - 其他
- PouchDB 有用资源
- PouchDB - 快速指南
- PouchDB - 有用资源
- PouchDB - 讨论
PouchDB - 同步
您可以将存储在 PouchDB 中的本地数据库与存储在 CouchDB 中的数据库同步。在上一章中,我们已经了解了如何使用 PouchDB 复制数据库。在那里,我们使用了方法PouchDB.replicate(source, destination)。
除此之外,我们还可以使用replicate.to()和replicate.from()方法将数据从本地数据库复制到远程数据库,以及从远程数据库复制到本地数据库,如下所示。
//Replicating data from local database to remote database localDB.replicate.to(remoteDB); //Replicating data from remote database to local database localDB.replicate.from(remoteDB);
其中,localDB是存储在 PouchDB 中的本地数据库的对象,remoteDB是存储在 CouchDB 中的数据库的对象。
示例
假设在 PouchDB 中有一个名为local_database的数据库,它包含 3 个文档,doc1、doc2 和 doc3,其内容如下所示。
doc1 = {_id: '003', name: 'Ram', age: 26, Designation: 'Programmer'} doc2 = {_id: '004', name: 'Robert', age: 27, Designation: 'Programmer'} doc3 = {_id: '005', name: 'Rahim', age: 28, Designation: 'Programmer'}
并且在 CouchDB 中有一个名为Remote_Database的数据库,它包含 2 个文档 doc1、doc2,其内容如下所示。
doc1 = {_id: '001', name: 'Geeta', age: 25, Designation: 'Programmer'} doc2 = {_id: '002', name: 'Zara Ali', age: 24, Designation: 'Manager'}
以下是如何使用replicate.to()和replicate.from()方法同步这两个数据库的示例,其中一个存储在 PouchDB 中,另一个存储在 CouchDB 中。
//Requiring the package var PouchDB = require('PouchDB'); //Creating local database object var localDB = new PouchDB('local_database'); //Creating remote database object var remoteDB = new PouchDB('https://127.0.0.1:5984/remote_database'); //Synchronising both databases localDB.replicate.to(remoteDB); remoteDB.replicate.from(localDB); console.log("Databases synchronized successfully");
将以上代码保存到名为Synchronising_databases.js的文件中。打开命令提示符并使用node执行 JavaScript 文件,如下所示。
C:\PouchDB_Examples >node Synchronising_databases.js
这将同步两个数据库 remoteDB 和 localDB,并在控制台上显示如下消息。
Databases synchronized successfully.
同步两个数据库后,访问http://127.0.0.1:5984/_utils/index.html并选择remote_database。您可以观察到本地数据库的文档(003、004、005)已复制到此数据库中,如下所示。
同样,如果您获取存储在 PouchDB 中的local_database的内容,您会发现存储在 CouchDB 中的数据库的文档已复制到这里。
[ { 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-bf4619471ac346fdde46cfa8fbf3587f' }, doc: { name: 'Ram', age: 26, Designation: 'Programmer', _id: '003', _rev: '1-bf4619471ac346fdde46cfa8fbf3587f' } }, { id: '004', key: '004', value: { rev: '1-29b8f803958c994e3eb37912a45d869c' }, doc: { name: 'Robert', age: 27, Designation: 'Programmer', _id: '004', _rev: '1-29b8f803958c994e3eb37912a45d869c' } }, { id: '005', key: '005', value: { rev: '1-0eb89f71998ffa8430a640fdb081abd2' }, doc: { name: 'Rahim', age: 28, Designation: 'Programmer', _id: '005', _rev: '1-0eb89f71998ffa8430a640fdb081abd2' } } ]
您可以使用 PouchDB 提供的sync()方法重写上述程序,而不是使用replicate.to()和replicate.from()这两个方法,如下所示。
//Requiring the package var PouchDB = require('PouchDB'); //Creating local database object var localDB = new PouchDB('local'); //Creating remote database object var remoteDB = new PouchDB('https://127.0.0.1:5984/remote_database'); //Synchronising Remote and local databases localDB.sync(remoteDB, function(err, response) { if (err) { return console.log(err); } else { console.log(response); } });
执行上述程序后,它将同步两个数据库并显示以下消息。
{ push: { ok: true, start_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time), docs_read: 6, docs_written: 6, doc_write_failures: 0, errors: [], last_seq: 10, status: 'complete', end_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time) }, pull: { ok: true, start_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time), docs_read: 0, docs_written: 0, doc_write_failures: 0, errors: [], last_seq: 2, status: 'complete', end_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time) } }