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
Теперь, если вы проверите документ, вы увидите прикрепленное к нему вложение, как показано на следующем снимке экрана.