PouchDB - การลบไฟล์แนบ
คุณสามารถลบไฟล์แนบจาก PouchDB โดยใช้ไฟล์ removeAttachment() วิธี.
ไวยากรณ์
ต่อไปนี้เป็นไวยากรณ์ของ removeAttachment()วิธี. วิธีนี้เราต้องส่งรหัสเอกสารรหัสเอกสารแนบและค่า _rev วิธีนี้ยังยอมรับฟังก์ชันเรียกกลับที่เป็นทางเลือก
db.removeAttachment ( docId, attachmentId, rev, [callback] );
ตัวอย่าง
สมมติว่ามีเอกสารใน PouchDB พร้อม id 001ซึ่งประกอบด้วยรหัสชื่ออายุการกำหนดของพนักงานพร้อมไฟล์แนบตามที่แสดงด้านล่าง
{
name: 'Raju',
age: 23,
designation: 'Designer',
_attachments: {
'att_1.txt': {
content_type: 'text/plain',
digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
data: 'AA=='
}
},
_id: '001',
_rev: '2-cdec6c9f45ddbee7d456945654742d43'
}
ต่อไปนี้เป็นตัวอย่างของการลบไฟล์แนบของเอกสารนี้ 001 เก็บไว้ใน PouchDB โดยใช้ไฟล์ removeAttachment() วิธี.
//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")
}
});
บันทึกรหัสด้านบนในไฟล์ที่มีชื่อ Remove_Attachment.js. เปิดพรอมต์คำสั่งและเรียกใช้ไฟล์ JavaScript โดยใช้node ดังแสดงด้านล่าง
C:\PouchDB_Examples >node Remove_Attachment.js
สิ่งนี้จะลบสิ่งที่แนบมาของเอกสารและแสดงข้อความบนคอนโซลดังที่แสดงด้านล่าง
Attachment deleted successfully
หลังจากการลบคุณสามารถตรวจสอบเนื้อหาของเอกสารได้โดยดำเนินการตามรหัสต่อไปนี้
//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);
}
});
บันทึกรหัสนี้เป็น read.jsและดำเนินการ ในการดำเนินการคุณจะได้รับเนื้อหาของเอกสารหลังจากลบไฟล์แนบดังที่แสดงด้านล่าง
{
name: 'Raju',
age: 23,
designation: 'Designer',
_id: '001',
_rev: '3-da775487a6ed0495f2e49c543384f8e8'
}
การลบสิ่งที่แนบมาจากเอกสารระยะไกล
คุณสามารถลบไฟล์แนบของเอกสารที่มีอยู่ในฐานข้อมูลที่จัดเก็บจากระยะไกลบนเซิร์ฟเวอร์ (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');
db.removeAttachment('001', 'att_1.txt', '2-049f1c4ffa54576ec0947b65e34de423',
function(err, res) {
if (err) {
return console.log(err);
} else {
console.log(res+"Attachment Deleted successfully")
}
});
บันทึกรหัสด้านบนในไฟล์ที่มีชื่อ Remote_Delete_Attachment.js. เปิดพรอมต์คำสั่งและเรียกใช้ไฟล์ JavaScript โดยใช้node ดังแสดงด้านล่าง
C:\PouchDB_Examples >node Remote_Delete_Attachment.js
สิ่งนี้จะลบไฟล์แนบที่มีอยู่และแสดงข้อความต่อไปนี้
Attachment Deleted successfully
หากคุณเข้าชมเอกสารอีกครั้งคุณจะสังเกตได้ว่าไฟล์แนบนั้นถูกลบไปแล้วดังที่แสดงในภาพหน้าจอต่อไปนี้