PouchDB - การเพิ่มไฟล์แนบ

คุณสามารถแนบวัตถุไบนารีเข้ากับเอกสารโดยใช้ไฟล์ putAttachment() วิธีการใน PouchDB

ไวยากรณ์

ต่อไปนี้เป็นไวยากรณ์ของ putAttachment(). วิธีนี้เราต้องส่งรหัสเอกสารรหัสเอกสารแนบประเภท MIME พร้อมกับไฟล์แนบ วิธีนี้ยังยอมรับฟังก์ชันเรียกกลับที่เป็นทางเลือก

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

เราสามารถเตรียมไฟล์แนบโดยใช้วัตถุหยดหรือบัฟเฟอร์ได้ที่ไหน 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 ด้วย id '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 โดยใช้ URLhttp://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

ตอนนี้หากคุณตรวจสอบเอกสารคุณสามารถสังเกตสิ่งที่แนบมาที่เพิ่มเข้าไปดังที่แสดงในภาพหน้าจอต่อไปนี้