MongoDB - คอลเลกชันที่ต่อยอด
Capped collectionsเป็นคอลเลกชันวงกลมขนาดคงที่ซึ่งเป็นไปตามลำดับการแทรกเพื่อรองรับประสิทธิภาพสูงสำหรับการสร้างอ่านและลบการดำเนินการ โดยวงกลมหมายความว่าเมื่อขนาดคงที่ที่จัดสรรให้กับคอลเล็กชันหมดลงจะเริ่มลบเอกสารที่เก่าที่สุดในคอลเล็กชันโดยไม่ต้องให้คำสั่งที่ชัดเจนใด ๆ
คอลเลกชันที่ต่อยอด จำกัด การอัปเดตเอกสารหากการอัปเดตส่งผลให้ขนาดเอกสารเพิ่มขึ้น เนื่องจากคอลเลกชันที่ต่อยอดจะจัดเก็บเอกสารตามลำดับของที่เก็บดิสก์จึงทำให้มั่นใจได้ว่าขนาดเอกสารจะไม่เพิ่มขนาดที่จัดสรรบนดิสก์ คอลเลกชันที่ต่อยอดเหมาะที่สุดสำหรับการจัดเก็บข้อมูลบันทึกข้อมูลแคชหรือข้อมูลปริมาณมากอื่น ๆ
การสร้างคอลเลกชันที่ต่อยอด
ในการสร้างคอลเลกชันที่ต่อยอดเราใช้คำสั่ง createCollection ปกติ แต่มี capped ตัวเลือกเป็น true และระบุขนาดสูงสุดของคอลเลกชันเป็นไบต์
>db.createCollection("cappedLogCollection",{capped:true,size:10000})
นอกจากขนาดคอลเลกชันแล้วเรายังสามารถ จำกัด จำนวนเอกสารในคอลเลกชันโดยใช้ไฟล์ max พารามิเตอร์ -
>db.createCollection("cappedLogCollection",{capped:true,size:10000,max:1000})
หากคุณต้องการตรวจสอบว่าคอลเลกชันถูกต่อยอดหรือไม่ให้ใช้สิ่งต่อไปนี้ isCapped คำสั่ง -
>db.cappedLogCollection.isCapped()
หากมีคอลเล็กชันที่มีอยู่ซึ่งคุณกำลังวางแผนที่จะแปลงเป็นต่อยอดคุณสามารถทำได้โดยใช้รหัสต่อไปนี้ -
>db.runCommand({"convertToCapped":"posts",size:10000})
รหัสนี้จะแปลงคอลเล็กชันที่มีอยู่ของเรา posts ไปยังคอลเลกชันที่ต่อยอด
กำลังค้นหาคอลเล็กชันที่มีการปิดทับ
ตามค่าเริ่มต้นค้นหาแบบสอบถามในคอลเลกชันที่มีการต่อยอดจะแสดงผลลัพธ์ตามลำดับการแทรก แต่ถ้าคุณต้องการดึงเอกสารในลำดับย้อนกลับให้ใช้ไฟล์sort คำสั่งดังแสดงในรหัสต่อไปนี้ -
>db.cappedLogCollection.find().sort({$natural:-1})
มีประเด็นสำคัญอื่น ๆ อีกเล็กน้อยเกี่ยวกับคอลเลกชันต่อยอดที่ควรรู้ -
เราไม่สามารถลบเอกสารจากคอลเลกชันที่ต่อยอดได้
ไม่มีดัชนีเริ่มต้นอยู่ในคอลเลกชันที่ต่อยอดแม้ในฟิลด์ _id
ในขณะที่ใส่เอกสารใหม่ MongoDB ไม่จำเป็นต้องมองหาสถานที่เพื่อรองรับเอกสารใหม่บนดิสก์ สามารถแทรกเอกสารใหม่ที่ส่วนท้ายของคอลเล็กชันแบบสุ่มสี่สุ่มห้า สิ่งนี้ทำให้การแทรกในคอลเลกชันที่ต่อยอดทำได้รวดเร็วมาก
ในทำนองเดียวกันในขณะที่อ่านเอกสาร MongoDB จะส่งคืนเอกสารในลำดับเดียวกับที่แสดงบนดิสก์ ทำให้การอ่านรวดเร็วมาก