Учебники

PouchDB — Добавление вложения

Вы можете прикрепить двоичный объект к документу, используя метод 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

Теперь, если вы проверите документ, вы можете увидеть добавленное к нему вложение, как показано на следующем снимке экрана.