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

Вы можете прикрепить бинарный объект к документу, используя putAttachment() в PouchDB.

Синтаксис

Ниже приводится синтаксис putAttachment(). В этот метод мы должны передать идентификатор документа, идентификатор вложения, тип MIME вместе с вложением. Этот метод также принимает дополнительную функцию обратного вызова.

db.putAttachment( docId, attachmentId, attachment, type, [callback] );

Мы можем подготовить вложение, используя blob или буферные объекты, где blob используется при работе с браузером и buffer используется при работе с 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, используяnode как показано ниже.

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 изменив значение id на 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, используяnode как показано ниже.

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, которая содержит документ, который необходимо прочитать.

пример

Предположим, есть база данных с именем my_databaseна сервере CouchDB. Затем, если вы проверите список баз данных в 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, используяnode как показано ниже.

C:\PouchDB_Examples >node Remote_Add_Attachment.js

Это добавляет вложение к указанному документу, отображая следующее сообщение.

Attachment added successfully

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