PouchDB最重要的功能之一是复制,即您可以复制数据库.您可以复制本地存储的PouchDB实例或远程存储的CouchDB实例.
以下是在PouchDB中复制数据库的语法.这里,源数据库的副本是目标.对于此方法,您可以直接以String格式传递源数据库和目标数据库的位置,也可以传递表示它们的对象.
PouchDB. replicate(source,target,[options])
源和目标都可以是PouchDB实例或CouchDB实例.
假设PouchDB中有一个名为 sample_database 的数据库,它包含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 的文件中.打开命令提示符并使用 node 执行JavaScript文件,如下所示.
C:\PouchDB_Examples >node Replication_example.js
这将在CouchDB实例中生成名为sample_database的数据库副本,并在控制台上显示一条消息,如下所示.
Database replicated successfully
您可以验证是否在CouchDB实例中复制了数据库点击以下链接 http://127.0.0.1:5984/_utils/index.html .
点击后,您可以看到您的数据库列表CouchDB的.您还可以在此处观察到数据库 sample_database 的副本.
如果选择复制数据库,则可以查看其内容,如下所示.
假设有一个名为 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 的文件中.打开命令提示符并使用 node 执行JavaScript文件,如下所示.
C:\PouchDB_Examples >node Replication_example2.js
这将在PouchDB实例中生成名为 remote_database 的数据库的副本,并在控制台上显示一条消息,如图所示下面.
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' } } ]