- 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 - 删除附件
您可以使用 **removeAttachment()** 方法从 PouchDB 中删除附件。
语法
以下是 **removeAttachment()** 方法的语法。对于此方法,我们必须传递文档 ID、附件 ID 和 _rev 值。此方法还接受一个可选的回调函数。
db.removeAttachment ( docId, attachmentId, rev, [callback] );
示例
假设 PouchDB 中有一个 ID 为 **001** 的文档,其中包含员工的 ID、姓名、年龄、职位以及附件,如下所示。
{ name: 'Raju', age: 23, designation: 'Designer', _attachments: { 'att_1.txt': { content_type: 'text/plain', digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==', data: 'AA==' } }, _id: '001', _rev: '2-cdec6c9f45ddbee7d456945654742d43' }
以下是如何使用 **removeAttachment()** 方法删除存储在 PouchDB 中的此文档 **001** 的附件的示例。
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('my'); db.removeAttachment('001', 'att_1.txt', '2-cdec6c9f45ddbee7d456945654742d43', function(err, res) { if (err) { return console.log(err); } else { console.log(res+"Attachment Deleted successfully") } });
将以上代码保存在名为 **Remove_Attachment.js** 的文件中。打开命令提示符并使用 **node** 执行 JavaScript 文件,如下所示。
C:\PouchDB_Examples >node Remove_Attachment.js
这将删除文档的附件并在控制台上显示一条消息,如下所示。
Attachment deleted successfully
删除后,您可以通过执行以下代码来验证文档的内容。
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('my_d'); //Reading the Document db.get('001',{attachments: true}, function(err, doc) { if (err) { return console.log(err); } else { console.log(doc); } });
将此代码另存为 **read.js** 并执行它。执行后,您将获得删除附件后文档的内容,如下所示。
{ name: 'Raju', age: 23, designation: 'Designer', _id: '001', _rev: '3-da775487a6ed0495f2e49c543384f8e8' }
从远程文档中删除附件
您可以删除数据库中已存在且远程存储在服务器(CouchDB)上的文档的附件。
为此,您需要传递 CouchDB 中包含要读取的文档的数据库的路径,而不是数据库名称。
示例
假设 CouchDB 服务器中有一个名为 **my_database** 的数据库。然后,如果您使用 URL **http://127.0.0.1:5984/_utils/index.html** 验证 CouchDB 中的数据库列表,您将获得以下屏幕截图。
如果您选择名为 **my_database** 的数据库,则可以查看其内容,如下所示。
假设此文档中有一个附件,如下所示。
以下是如何删除上述文档 **001** 的附件的示例,该文档存在于名为 **my_database** 的数据库中,该数据库存储在 CouchDB 服务器中。
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('https://127.0.0.1:5984/my_database'); db.removeAttachment('001', 'att_1.txt', '2-049f1c4ffa54576ec0947b65e34de423', function(err, res) { if (err) { return console.log(err); } else { console.log(res+"Attachment Deleted successfully") } });
将以上代码保存在名为 **Remote_Delete_Attachment.js** 的文件中。打开命令提示符并使用 **node** 执行 JavaScript 文件,如下所示。
C:\PouchDB_Examples >node Remote_Delete_Attachment.js
这将删除现有附件并显示以下消息。
Attachment Deleted successfully
如果您再次访问该文档,您会注意到附件已被删除,如下面的屏幕截图所示。