PouchDB - usuwanie załącznika

Możesz usunąć załącznik z PouchDB za pomocą removeAttachment() metoda.

Składnia

Poniżej znajduje się składnia removeAttachment()metoda. Do tej metody musimy przekazać identyfikator dokumentu, identyfikator załącznika i wartość _rev. Ta metoda akceptuje również opcjonalną funkcję zwrotną.

db.removeAttachment ( docId, attachmentId, rev, [callback] );

Przykład

Załóżmy, że w PouchDB znajduje się dokument o identyfikatorze 001, który zawiera identyfikator, imię i nazwisko, wiek, oznaczenie pracownika wraz z załącznikiem, jak pokazano poniżej.

{ 
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _attachments: { 
      'att_1.txt': { 
         content_type: 'text/plain',
         digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
         data: 'AA==' 
      } 
   },
   _id: '001',
   _rev: '2-cdec6c9f45ddbee7d456945654742d43' 
}

Poniżej znajduje się przykład usuwania załącznika tego dokumentu 001 przechowywane w PouchDB przy użyciu removeAttachment() metoda.

//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")
   }
});

Zapisz powyższy kod w pliku o nazwie Remove_Attachment.js. Otwórz wiersz polecenia i uruchom plik JavaScript za pomocąnode jak pokazano niżej.

C:\PouchDB_Examples >node Remove_Attachment.js

Spowoduje to usunięcie załącznika dokumentu i wyświetlenie komunikatu na konsoli, jak pokazano poniżej.

Attachment deleted successfully

Po usunięciu możesz zweryfikować zawartość dokumentu, wykonując następujący kod.

//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);
   }
});

Zapisz ten kod jako read.jsi wykonaj to. Podczas wykonywania otrzymasz zawartość dokumentu po usunięciu załącznika, jak pokazano poniżej.

{ 
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _id: '001',
   _rev: '3-da775487a6ed0495f2e49c543384f8e8' 
}

Usuwanie załącznika ze zdalnego dokumentu

Możesz usunąć załącznik z istniejącego dokumentu w bazie danych, który jest przechowywany zdalnie na serwerze (CouchDB).

W tym celu zamiast nazwy bazy danych należy podać ścieżkę do bazy w CouchDB, w której znajduje się dokument przeznaczony do odczytania.

Przykład

Załóżmy, że istnieje baza danych o nazwie my_databasena serwerze CouchDB. Następnie, jeśli zweryfikujesz listę baz danych w CouchDB za pomocą adresu URLhttp://127.0.0.1:5984/_utils/index.html otrzymasz następujący zrzut ekranu.

A jeśli wybierzesz bazę danych o nazwie my_database, możesz wyświetlić jego zawartość, jak pokazano poniżej.

Załóżmy, że w tym dokumencie znajduje się załącznik, jak pokazano poniżej.

Poniżej znajduje się przykład usunięcia wyżej wymienionego załącznika dokumentu 001 który istnieje w bazie danych o nazwie my_database który jest przechowywany na serwerze CouchDB.

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object 
var db = new PouchDB('http://localhost: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") 
   } 
});

Zapisz powyższy kod w pliku o nazwie Remote_Delete_Attachment.js. Otwórz wiersz polecenia i uruchom plik JavaScript za pomocąnode jak pokazano niżej.

C:\PouchDB_Examples >node Remote_Delete_Attachment.js

Spowoduje to usunięcie istniejącego załącznika i wyświetlenie następującego komunikatu.

Attachment Deleted successfully

Jeśli ponownie odwiedzisz dokument, możesz zauważyć, że załącznik został usunięty, jak pokazano na poniższym zrzucie ekranu.