Вы можете прикрепить двоичный объект к документу, используя метод putAttachment () в PouchDB.
Синтаксис
Ниже приводится синтаксис метода putAttachment () . Для этого метода мы должны передать идентификатор документа, идентификатор вложения, MIME-тип вместе с вложением. Этот метод также принимает дополнительную функцию обратного вызова.
db.putAttachment( docId, attachmentId, attachment, type, [callback] );
Мы можем подготовить вложение, используя объекты blob или buffer, где blob используется при работе с браузером, а буфер используется при работе с Node.js , поскольку мы демонстрируем наши программы в Node.js, мы используем объекты буфера для подготовки документов.
пример
Ниже приведен пример создания документа с вложением в базе данных my_database в PouchDB с использованием метода putAttachment () .
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('my_database'); //Preparing the attachment var my_attachment = new Buffer(['Welcome to tutorialspoint'], {type: 'text/plain'}); //Adding attachment to a document db.putAttachment('001', 'att_1.txt', my_attachment, 'text/plain', function(err, res) { if (err) { return console.log(err); } else { console.log(res+"Attachment added successfully") } });
Сохраните приведенный выше код в файле с именем Add_Attachment.js . Откройте командную строку и выполните файл JavaScript, используя узел, как показано ниже.
C:\PouchDB_Examples >node Add_Attachment.js
Это создает пустой документ с добавлением вложения в него в базе данных my_database, которая хранится в PouchDB, и отображает следующее сообщение.
Attachment added successfully
Вы можете проверить, добавлено ли вложение, прочитав документ, используя следующий код.
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('my_database'); //Reading the Document db.get('001',{attachments: true}, function(err, doc) { if (err) { return console.log(err); } else { console.log(doc); } });
Сохраните приведенный выше код как read_doc.js и выполните его. Запустив эту программу, вы можете увидеть следующее содержимое документа.
{ _attachments: { att_1.txt: { content_type: 'text/plain', digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==', data: 'AA==' } }, _id: '001', _rev: '1-620fd5f41d3328fcbf9ce7504338a51d' }
Добавление вложения в существующий документ
Предположим, в базе данных есть документ с именем my_database PouchDB с идентификатором ‘ 002 ‘. Вы можете получить его содержимое, выполнив read_doc.js , изменив значение идентификатора на 002 , как показано ниже.
{ name: 'Raju', age: 23, designation: 'Designer', _id: '002', _rev: '1-05ca7b5f3f4762a9fb2d119cd34c8d40' }
Теперь вы можете добавить вложение в этот документ, используя его значение _rev .
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('my_database'); //Adding attachment to existing document var my_attachment = new Buffer (['Welcome to tutorialspoint'], {type: 'text/plain'}); rev = '1-05ca7b5f3f4762a9fb2d119cd34c8d40'; db.putAttachment('002', 'att_1.txt', rev , my_attachment, 'text/plain', function(err, res) { if (err) { return console.log(err); } else { console.log (res + "Attachment added successfully") } });
Сохраните приведенный выше код в файле с именем Add_Attachment_to_doc.js . Откройте командную строку и выполните файл JavaScript, используя узел, как показано ниже.
C:\PouchDB_Examples >node Add_Attachment_to_doc.js
Это добавит вложение к указанному документу, отображающее следующее сообщение.
Attachment added successfully
Если вы измените значение id в read_doc.js на 002 и выполните его, вы получите следующий вывод.
{ name: 'Raju', age: 23, designation: 'Designer', _attachments: { att_1: { content_type: 'text/plain', digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==', data: 'AA==' } }, _id: '002', _rev: '2-3bb4891b954699bce28346723cc7a709' }
Добавление вложения в удаленный документ
Вы даже можете добавить вложение к документу, существующему в базе данных, которая удаленно хранится на сервере (CouchDB).
Для этого вместо имени базы данных вам нужно передать путь к базе данных в CouchDB, которая содержит документ, который должен быть прочитан.
пример
Предположим, что на сервере CouchDB есть база данных с именем my_database . Затем, если вы проверите список баз данных в CouchDB, используя URL-адрес http://127.0.0.1:5984/_utils/index.html, вы получите следующий снимок экрана.
И если вы выберете базу данных с именем my_database , вы можете просмотреть ее содержимое, как показано ниже.
Ниже приведен пример добавления вложения в документ 001, хранящийся в базе данных с именем my_database, которая хранится на сервере CouchDB.
//Requiring the package var PouchDB = require('PouchDB'); //Creating the database object var db = new PouchDB('http://localhost:5984/my_database'); //Adding attachment to existing document var my_attachment = new Buffer (['Welcome to tutorialspoint'], {type: 'text/plain'}); rev = '1-36c34fdcf29a652876219065f9681602'; db.putAttachment('001', 'att_1.txt',rev, my_attachment, 'text/plain', function(err, res) { if (err) { return console.log(err); } else { console.log (res+ "Attachment added successfully") } });
Сохраните приведенный выше код в файле с именем Remote_Add_Attachment.js . Откройте командную строку и выполните файл JavaScript, используя узел, как показано ниже.
C:\PouchDB_Examples >node Remote_Add_Attachment.js
Это добавит вложение к указанному документу, отображающее следующее сообщение.
Attachment added successfully
Теперь, если вы проверите документ, вы можете увидеть добавленное к нему вложение, как показано на следующем снимке экрана.