ภาพรวมดัชนี

เกี่ยวข้องกับ Cloud Firestore Enterprise Edition เท่านั้น

หน้านี้อธิบายการจัดทำดัชนีสำหรับ Cloud Firestore ที่เข้ากันได้กับ MongoDB Cloud Firestore ที่มีความเข้ากันได้กับ MongoDB จะไม่สร้างดัชนีใดๆ โดยค่าเริ่มต้น สร้างดัชนีสําหรับการค้นหาที่ใช้บ่อยที่สุดเพื่อปรับปรุงประสิทธิภาพของฐานข้อมูล

ดัชนีมีผลกระทบอย่างมากต่อประสิทธิภาพของฐานข้อมูล หากมีการสร้างดัชนีสำหรับการค้นหา ฐานข้อมูลจะแสดงผลลัพธ์ได้อย่างมีประสิทธิภาพโดยการลดปริมาณข้อมูลที่ต้องสแกนและลดงานที่ต้องใช้ในการจัดเรียงผลลัพธ์ อย่างไรก็ตาม รายการดัชนีจะเพิ่มต้นทุนพื้นที่เก็บข้อมูลและปริมาณงาน ที่ทำในระหว่างการดำเนินการเขียนในช่องที่ทำดัชนี

คำจำกัดความและโครงสร้างดัชนี

ดัชนีประกอบด้วยข้อมูลต่อไปนี้

  • รหัสคอลเล็กชัน
  • รายการฟิลด์ในคอลเล็กชันที่ระบุ
  • ลำดับจากน้อยไปมากหรือมากไปน้อยสำหรับแต่ละฟิลด์

ดัชนียังเปิดใช้ตัวเลือก sparse, multikey หรือ unique ได้ด้วย

การจัดเรียงดัชนี

ลำดับและทิศทางการจัดเรียงของแต่ละฟิลด์จะกำหนดดัชนีโดยไม่ซ้ำกัน ตัวอย่างเช่น ดัชนีต่อไปนี้เป็นดัชนีที่แตกต่างกัน 2 รายการและไม่สามารถใช้แทนกันได้

การรวบรวม ช่อง
เมือง ประเทศ (จากน้อยไปมาก), ประชากร (จากมากไปน้อย)
เมือง ประชากร (จากมากไปน้อย), ประเทศ (จากน้อยไปมาก)

เมื่อสร้างดัชนีเพื่อรองรับการค้นหา ให้รวมฟิลด์ตามลำดับเดียวกับการค้นหา

ความหนาแน่นของดัชนี

โดยค่าเริ่มต้น รายการดัชนีจะจัดเก็บข้อมูลจากเอกสารทั้งหมดในคอลเล็กชัน ซึ่งเรียกว่าดัชนีแบบไม่กระจัดกระจาย ระบบจะเพิ่มรายการดัชนีสำหรับเอกสารไม่ว่าเอกสารจะมีฟิลด์ที่ระบุในดัชนีหรือไม่ก็ตาม ระบบจะถือว่าฟิลด์ที่ไม่มีอยู่มีค่า NULL เมื่อสร้างรายการดัชนี หากต้องการเปลี่ยนลักษณะการทำงานนี้ คุณสามารถกำหนดดัชนีเป็นดัชนีแบบกระจัดกระจายได้

ดัชนีแบบกระจาย

ดัชนีแบบกระจัดกระจายจะจัดทำดัชนีเฉพาะเอกสารในคอลเล็กชันที่มีค่า (รวมถึงค่า Null) สำหรับฟิลด์ที่จัดทำดัชนีอย่างน้อย 1 ฟิลด์ ดัชนีแบบกระจายช่วยลดต้นทุนพื้นที่เก็บข้อมูลและเพิ่มประสิทธิภาพได้

ดัชนีหลายคีย์สำหรับค่าอาร์เรย์

หากสร้างดัชนีในฟิลด์ที่มีค่าอาร์เรย์ คุณต้องสร้างดัชนีแบบหลายคีย์ ดัชนีปกติไม่สามารถ จัดทำดัชนีค่าอาร์เรย์ ดัชนีแบบหลายคีย์รองรับฟิลด์อาร์เรย์ได้สูงสุด 1 รายการใน คำจำกัดความดัชนี และใช้กับการดำเนินการที่ข้ามค่าอาร์เรย์ได้

ใช้ดัชนีแบบหลายคีย์เฉพาะในกรณีที่คุณทราบว่าต้องจัดทำดัชนีค่าอาร์เรย์ ดัชนีปกติมีข้อดีเมื่อประมวลผลการค้นหา ตัวอย่างเช่น ดัชนีปกติ สามารถกรองค่าภายในช่วงได้อย่างมีประสิทธิภาพมากขึ้น

สถานการณ์ต่อไปนี้ทำให้เกิดข้อผิดพลาดเมื่อทำงานกับค่าอาร์เรย์และดัชนีแบบหลายคีย์

  • การดำเนินการพยายามเพิ่มค่าอาร์เรย์ลงในฟิลด์ที่จัดทำดัชนีโดยดัชนีปกติ หากต้องการเพิ่มค่าอาร์เรย์ คุณต้องลบดัชนีปกติที่มีอยู่ ในฟิลด์นั้น แล้วสร้างใหม่เป็นดัชนีแบบหลายคีย์
  • คุณพยายามสร้างดัชนีปกติในฟิลด์ที่มีค่าอาร์เรย์ คุณต้องสร้างดัชนีแบบหลายคีย์หรือลบค่าอาร์เรย์
  • การดำเนินการพยายามจัดทำดัชนีช่องหลายช่องที่มีค่าอาร์เรย์ คุณ ไม่สามารถมีฟิลด์ที่มีค่าอาร์เรย์มากกว่า 1 ฟิลด์ในดัชนีแบบหลายคีย์ หากต้องการดำเนินการต่อ ให้แก้ไขโมเดลข้อมูลหรือคำจำกัดความดัชนี
  • คุณพยายามสร้างดัชนีแบบหลายคีย์ที่เส้นทางฟิลด์ 2 เส้นทางใช้คำนำหน้าร่วมกัน เช่น users.posts และ users.zip

ดัชนีที่ไม่ซ้ำกัน

ตั้งค่าตัวเลือกดัชนีที่ไม่ซ้ำกันเพื่อบังคับใช้ค่าที่ไม่ซ้ำกันสำหรับช่องที่จัดทำดัชนี สำหรับดัชนีในหลายฟิลด์ ชุดค่าผสมแต่ละชุดต้องไม่ซ้ำกัน ในดัชนี ฐานข้อมูลจะปฏิเสธการอัปเดตและการแทรกใดๆ ที่ พยายามสร้างรายการดัชนีที่มีค่าซ้ำ หากข้อมูล ของฟิลด์ที่จัดทำดัชนีมีค่าที่ซ้ำกันและคุณพยายาม สร้างดัชนีที่ไม่ซ้ำกัน การสร้างดัชนีจะล้มเหลวพร้อมข้อความแสดงข้อผิดพลาด ในรายละเอียดการดำเนินการ

ฟิลด์ที่ไม่มีในดัชนีที่ไม่ซ้ำกัน

หากคุณแทรกเอกสารที่มีฟิลด์ที่ขาดหายไปสำหรับดัชนีที่ไม่ซ้ำกัน ดัชนีจะตั้งค่า null สำหรับฟิลด์ที่ขาดหายไป รายการดัชนีที่ได้ต้องไม่ซ้ำกัน มิเช่นนั้นการดำเนินการจะล้มเหลว

เช่น หากมีดัชนีนี้

db.cities.createIndex( { "name": 1 }, { unique: true } )

หากคุณเพิ่มเอกสาร {"abbreviation": "LA"} ลงในคอลเล็กชัน ดัชนีที่ไม่ซ้ำกัน จะสร้างรายการที่มี name ตั้งค่าเป็น null หากคุณพยายามเพิ่ม เอกสาร{"abbreviation": "NYC"}ในภายหลัง การดำเนินการจะไม่สำเร็จเนื่องจาก รายการที่ได้สำหรับดัชนีที่ไม่ซ้ำกันจะเหมือนกัน

ลักษณะการทำงานเดียวกันนี้จะมีผลกับดัชนีที่ไม่ซ้ำกันที่มีหลายฟิลด์ เมื่อสร้างหรืออัปเดตเอกสาร ระบบจะตั้งค่าฟิลด์ที่ขาดหายไปซึ่งมีการจัดทำดัชนีเป็น null และรายการดัชนีที่ได้ต้องไม่ซ้ำกันในดัชนี

แก้ปัญหาข้อผิดพลาดในการสร้างดัชนี

คุณอาจพบข้อผิดพลาดในการสร้างดัชนีเมื่อจัดการดัชนี การดำเนินการจัดทำดัชนีอาจล้มเหลวหากฐานข้อมูลพบปัญหาเกี่ยวกับข้อมูล การดำเนินการจัดทำดัชนีอาจล้มเหลวเนื่องจากสาเหตุต่อไปนี้

  • คุณใช้ดัชนีถึงขีดจำกัดแล้ว เช่น การดำเนินการอาจมี รายการดัชนีต่อเอกสารถึงจำนวนสูงสุดแล้ว หากการสร้างดัชนีล้มเหลว คุณจะเห็นข้อความแสดงข้อผิดพลาด หากยังไม่ถึงขีดจำกัดดัชนี ให้ลองดำเนินการจัดทำดัชนีอีกครั้ง
  • ต้องมีดัชนีแบบหลายคีย์ ฟิลด์ที่จัดทำดัชนีอย่างน้อย 1 รายการ มีค่าอาร์เรย์ หากต้องการดำเนินการต่อ คุณต้องใช้ดัชนีแบบหลายคีย์ หรือลบค่าอาร์เรย์
  • การดำเนินการพยายามจัดทำดัชนีช่องหลายช่องที่มีค่าอาร์เรย์ คุณ ไม่สามารถมีฟิลด์ที่มีค่าอาร์เรย์มากกว่า 1 ฟิลด์ในดัชนีแบบหลายคีย์ หากต้องการดำเนินการต่อ ให้แก้ไขโมเดลข้อมูลหรือคำจำกัดความดัชนี
  • คุณตั้งค่าตัวเลือกดัชนีที่ไม่ซ้ำกันและข้อมูลของช่องที่จัดทำดัชนีจะ สร้างรายการดัชนีที่ซ้ำกัน หากต้องการดำเนินการต่อ ให้นำค่าที่ซ้ำกัน ออกจากข้อมูล

ขั้นตอนถัดไป