Tutorial

Database Design Principle

By Arnon Puitrakul - 05 กรกฎาคม 2015

Database Design Principle

จาก EP. ที่แล้ว เราก็ได้รู้ว่า กว่าจะมาเป็น Database แบบที่เราใช้อยู่ทุกวันนี้ มันเริ่มมาจากอะไร และมีข้อดีข้อเสียอย่างไร
แต่วันนี้ เราจะไม่ย้อนเวลาแล้ว เราจะมองที่ปัจจุบัน มาดูกันว่า เวลาเราจะวาด ER Diagram ที่เขาวาด ๆ กันได้ยังไง แต่ก่อนหน้านั้น มันคืออะไร ?

ER Diagram คืออะไร ?

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

ส่วนประกอบของ ER Diagram

สำหรับแผนภาพ ER Diagram เราจะนำเสนอข้อมูลในรูปแบบของแผนภาพได้อย่างชัดเจน โดยจะมี

  1. Entity - ถ้าเราเคยลองเล่นกับฐานข้อมูล เจ้านี่มันก็จะอยู่ในรูปแบบของ Table ใน Database หรือถ้าใครยังไม่เคยเล่น มันก็คือ ข้อมูลตัวหนึ่ง เช่น พนักงาน นักเรียน อะไรแบบนี้เป็นต้น
  2. Strong Entity - ข้อมูลชนิดนี้มันจะไม่ขึ้นกับ Entity อื่น ๆ เช่น สินค้า นักศึกษา พนักงาน เป็นต้น
  3. Weak Entity - คือข้อมูลที่เกิดจาก Entity อื่น ๆ เช่น เกรดของนักศึกษา เป็นต้น
  4. Attribute - เราอาจเรียกว่า Field ในฐานข้อมูลก็ได้ มันก็คือ ข้อมูลที่ใช้อธิบายคุณสมบัติของ Entity ยกตัวอย่างง่าย ๆ ถ้าเรามี Entity สินค้า Attribute ของเราก็น่าจะมี รหัสสินค้า, ชื่อสินค้า และ ราคาสินค้าเป็นต้น
  5. Relation หรือความสัมพันธ์ ก็ตามชื่อเลย มันคือ ความเกี่ยวข้องระหว่าง Entity หนึ่งกับ Entity หนึ่ง
    เราลองมาดู ตัวอย่างกัน เราจะลองสร้าง ฐานข้อมูลเพื่อเก็บ การส่งหนังสือพิมพ์ให้ลูกค้า ก่อนอื่นมาดูที่ Entity แรกนั่นคือ Member ใน Entity นี้เราจะเก็บรายละเอียดของสมาชิกของเรา เพราะฉะนั้น Attribute ก็น่าจะมี เลขที่สมาชิก ชื่อ สกุล และที่อยู่ ถ้าเราเอา Entity นี้มาเขียนเป็น ER Diagram ก็จะได้ตามด้านล่าง

ERPersonEP1

ถัดมา เราก็ต้องมี Entity อีกตัวเพื่อเก็บข้อมูลของหนังสือพิมพ์ เช่น รหัสหนังสือพิมพ์ ชื่อหนังสือพิมพ์ และ ราคา สามารถเอามาเขียน ER Diagram ได้ตามแบบข้างล่างได้เลย

ERNewspaperEP1

หลังจากที่เราได้ ทั้ง 2 Entities ไปแล้ว เราก็จะมาดูที่อีก Entity นึง แต่ Entity นี้ออกจะพิเศษไปสักหน่อย เพราะว่า ข้อมูลของมันเกิดจาก ความสัมพันธ์ของ 2 Entities นั่นคือ News Member ซึ่ง Entity นี้จะเก็บข้อมูลว่าสมาชิกของเรานั่น สมัครสมาชิก หนังสือพิมพ์อะไรไปบ้าง ดังนั้น Attribute เราก็ควรจะมี รหัสสมาชิก ที่มาจาก Entity Member และ รหัสของหนังสือพิมพ์ที่สมาชิก ได้สมัครไว้

ERNewsMemberEP1

และเราก็จับทั้งหมดมารวมกัน เราก็จะได้แบบด้านล่างเลย

ERNewsMemberSystemEP1

แต่เราสังเกตจากตัวอย่างเมื่อกี้ ว่าสมาชิก 1 คนสามารถสมัครได้มากกว่า 1 หนังสือพิมพ์ ดังนั้นเรื่องของ ระดับของความสัมพันธ์ หรือ Relationship cardinality จึงถูกพูดขึ้นมา มันเป็นการอธิบายว่า ความสัมพันธ์อันนั้น ๆ มันมีความสัมพันธ์กันอย่างไร โดยเราจะมีอยู่ 3 รูปแบบด้วยกัน นั่นคือ

  • 1-1 Relationship หมายถึงข้อมูลเพียง 1 ข้อมูลใน Entity สัมพันธ์กับแค่ 1 ข้อมูล ของอีก Entity เท่าน้ัน เช่น คนขับรถ กับ รถ ที่รถ 1 คันก็จะต้องมี คนขับเพียง 1 คนเป็นต้น
  • 1-many Relationship หมายถึงข้อมูลเพียง 1 ข้อมูลใน Entity สัมพันธ์กับหลาย ๆ ข้อมูลของอีก Entity นึง เช่นตัวอย่าง สมาชิกหนังสือพิมพ์ที่ได้ยกตัวอย่างไป เราจะเห็นได้ว่า สมาชิก 1 คนสามารถสมัครสมาชิกของหนังสือพิมพ์หลาย ๆ ฉบับได้
  • many-many Relationship ก็จะหมายถึงข้อมูลหลาย ๆ ข้อมูลใน Entity สัมพันธ์กับหลาย ๆ ข้อมูลของอีก Entity นึง เช่น นักเรียน หลาย ๆ คน สามารถลง วิชาเรียนเดียวกันได้ แต่ในทางกลับกัน วิชา 1 วิชาก็สามารถถูกนักเรียนลงหลาย ๆ คนได้เช่นกัน
    และก็จบแล้วกับเรื่องแรกของเรากับการเขียน ER Diagram ถ้าคิดให้ง่าย ๆ ใน ER Diagram ก็จะประกอบไปด้วย Entity, Attribute และ Relation ที่ถูกแทนด้วย สี่เหลี่ยม, วงรี และเส้นมาประกอบกันเพื่ออธิบายความสัมพันธ์ของข้อมูลที่เราต้องการนั่นเอง

Read Next...

สร้าง Book Tracking Library ด้วย Obsidian

สร้าง Book Tracking Library ด้วย Obsidian

เราเป็นคนที่อ่านกับซื้อหนังสือเยอะมาก ปัญหานึงที่ประสบมาหลายรอบและน่าหงุดหงิดมาก ๆ คือ ซื้อหนังสือซ้ำเจ้าค่ะ ทำให้เราจะต้องมีระบบง่าย ๆ สักตัวในการจัดการ วันนี้เลยจะมาเล่าวิธีการที่เราใช้ Obsidian ในการจัดการหนังสือที่เรามีกัน...

Garbage Collector บน Python ทำงานอย่างไร

Garbage Collector บน Python ทำงานอย่างไร

หากเราเรียนลงลึกไปในภาษาใหม่ ๆ อย่าง Python และ Java โดยเฉพาะในเรื่องของการจัดการ Memory ว่าเขาใช้ Garbage Collection นะ ว่าแต่มันทำงานยังไง วันนี้เราจะมาเล่าให้อ่านกันว่า จริง ๆ แล้วมันทำงานอย่างไร และมันมีเคสใดที่อาจจะหลุดจนเราต้องเข้ามาจัดการเองบ้าง...

ติดตั้ง Zigbee Dongle บน Synology NAS กับ Home Assistant

ติดตั้ง Zigbee Dongle บน Synology NAS กับ Home Assistant

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

โหลด CSV วิธีไหนเร็วที่สุด ?

โหลด CSV วิธีไหนเร็วที่สุด ?

เมื่อหลายวันก่อนมีพี่ที่รู้จักกันมาถามว่า เราจะโหลด CSV ยังไงให้เร็วที่สุด เป็นคำถามที่ดูเหมือนง่ายนะ แต่พอมานั่งคิด ๆ ต่อ เห้ย มันมีอะไรสนุก ๆ ในนั้นเยอะเลยนี่หว่า วันนี้เราจะมาเล่าให้อ่านกันว่า มันมีวิธีการอย่างไรบ้าง และวิธีไหนเร็วที่สุด เหมาะกับงานแบบไหน...