ความแตกต่างระหว่างคีย์หลักในฐานข้อมูลเชิงสัมพันธ์และ NoSQL

เผยแพร่แล้ว: 2022-11-17

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

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

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

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

แต่ละตารางต้องมีคีย์หลักของตนเอง คีย์หลักสามารถเป็นชุดของพาร์ติชันคีย์หรืออาจมีส่วนประกอบของคลัสเตอร์ เนื่องจากค่าของคุณสมบัติแฮชของพาร์ติชันคีย์ Apache Cassandra ข้อมูลจะถูกเก็บไว้ที่โหนดที่มีค่าแฮชสูงสุดเสมอ

คีย์หลักได้รับการสนับสนุนในทุกตาราง (ควรสนับสนุนคีย์หลายคอลัมน์ในทุกตาราง) ไม่สามารถลบตารางด้วยคีย์หลักได้ แถวในตารางที่ไม่มีคีย์หลักอาจปรากฏในลำดับที่แตกต่างกัน ขึ้นอยู่กับโหนดที่เก็บคีย์หลัก

Nosql มีคีย์หลักและคีย์ต่างประเทศหรือไม่

ภาพโดย – สื่อ

ข้อมูลในฐานข้อมูล NoSQL ถูกจัดเก็บโดยไม่มีความสัมพันธ์เชิงสัมพันธ์ ไม่มีตาราง แถว คีย์หลัก หรือคีย์นอกในฐานข้อมูลนี้ เช่นเดียวกับในฐานข้อมูลเชิงสัมพันธ์

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

ฐานข้อมูล Nosql: ดี ไม่ดี และน่าเกลียด

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

Nosql มีคีย์ต่างประเทศหรือไม่

รูปภาพโดย – imgur

ฐานข้อมูล NoSQL ไม่รองรับคีย์นอกหรือการรวม และไม่สนับสนุนแนวคิดของ Referential Integrity ในส่วนนี้ เราจะดูประเภทต่างๆ ของฐานข้อมูล NoSQL และการใช้งาน

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

Nosql เป็นที่เก็บค่าคีย์หรือไม่

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

Mongodb: ที่เก็บข้อมูลคีย์-ค่าสำหรับข้อมูลด้วยโครงสร้างที่เรียบง่าย

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

Mongodb มีคีย์หลักหรือไม่?

ใช่ MongoDB มีคีย์หลัก คีย์หลักคือคีย์เฉพาะที่ใช้เพื่อระบุบันทึกในตารางฐานข้อมูล

เราจะพยายามหาทางออกในการสร้างคีย์หลักใน Mongodb ผ่านการเขียนโปรแกรม สามารถแสดงให้เห็นได้ในโค้ดต่อไปนี้ ทุกแถวในตารางได้รับการกำหนดคีย์ที่แตกต่างกันโดยค่าเริ่มต้น เมื่ออ่านหรือแก้ไขแถวใน Oracle NoSQL Database Cloud จะใช้คีย์เพื่อดึงแถว MongoDB ไม่รองรับความสัมพันธ์ของคีย์หลักกับคีย์ ต่างประเทศ ซึ่งเป็นเหตุผลว่าทำไมจึงไม่รองรับ คอลัมน์หลักในตารางหลักเป็นหนึ่งในคอลัมน์ที่กล่าวถึงในตารางรอง กระบวนการแก้ไขภายในของเอกสารติดตามโดย field_v ตัวระบุ ObjectID ที่ MongoDB สร้างขึ้นสำหรับแต่ละเอกสารนั้นไม่ซ้ำกันสำหรับเอกสารนั้น

DynamoDB เป็นบริการฐานข้อมูล NoSQL ที่รวดเร็วและปรับขนาดได้ ซึ่งรองรับข้อมูลคีย์-ค่า DynamoDB เป็นตัวเลือกที่ยอดเยี่ยมสำหรับการจัดเก็บข้อมูลด้วยแอตทริบิวต์ “คีย์-ค่า” เนื่องจากมีสคีมาที่ยืดหยุ่นและภาษาการสืบค้นที่หลากหลาย รวมถึง ดัชนีรอง ฐานข้อมูล MongoDB เป็นแพลตฟอร์มที่เหมาะสำหรับการพัฒนาแอพพลิเคชั่นที่หลากหลาย โมเดลข้อมูลคีย์-ค่าของ MongoDB ทำให้เป็นแพลตฟอร์มที่เหมาะสำหรับการจัดเก็บข้อมูลที่ประกอบด้วยคู่คีย์-ค่าสองคู่ นอกจากนี้ MongoDB ยังมีภาษาคิวรีที่มีประสิทธิภาพพร้อมดัชนีรอง ทำให้เป็นเครื่องมือที่ยอดเยี่ยมสำหรับการวิเคราะห์ข้อมูล

Mongodb มีคีย์หลักหรือไม่?

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

เราสามารถอัปเดตคีย์หลักใน Mongodb ได้หรือไม่

คีย์หลักประกอบด้วย char, short, int, long, string และ MongoDB รหัสวัตถุสอดคล้องกับชื่อของวัตถุ แอตทริบิวต์คุณสมบัติสามารถกำหนดเป็นคีย์หลักได้หลังจากที่เพิ่มไปยังขอบเขตแล้วเท่านั้น

คีย์หลักใน Mongodb

คีย์หลักเป็นตัวระบุเฉพาะสำหรับเอกสารในคอลเลกชัน MongoDB ตามค่าเริ่มต้น MongoDB จะสร้างคีย์หลักสำหรับแต่ละเอกสารในคอลเล็กชันชื่อ _id ฟิลด์ _id คือ ObjectId ขนาด 12 ไบต์

คีย์หลักของพังพอน

ใน Mongoose คีย์หลักจะถูกกำหนดให้กับฟิลด์ _id โดยอัตโนมัติ ฟิลด์ _id คือ ObjectId ขนาด 12 ไบต์ที่ไม่ซ้ำกันสำหรับแต่ละเอกสาร