ใช้ความสัมพันธ์

เริ่มต้นใช้งานความสัมพันธ์ของตาราง

เบราว์เซอร์ของคุณไม่สนับสนุนวิดีโอ

ลองกันเลย!

พลังของฐานข้อมูลเชิงสัมพันธ์อยู่ในการรวมข้อมูลข้ามตาราง เมื่อต้องการทําเช่นนั้น ก่อนอื่นคุณต้องสร้างความสัมพันธ์ระหว่างตารางของคุณ จากนั้นให้ให้ Access ทํางานเพื่อรวมข้อมูลในคิวรี ฟอร์ม และรายงาน

เมื่อต้องการดูความสัมพันธ์ที่มีอยู่ทั้งหมดที่กําหนดไว้สําหรับฐานข้อมูล ให้เปิดเทมเพลต Access ไปที่แท็บ เครื่องมือฐานข้อมูล แล้วเลือก ความสัมพันธ์

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

การทําความเข้าใจมุมมองความสัมพันธ์

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

ความสัมพันธ์จะแสดงตามเส้นที่วาดระหว่างเขตข้อมูลหลักและเขตข้อมูลรอง

เส้นและสัญลักษณ์จะแสดงให้คุณเห็นว่าตารางของคุณสัมพันธ์กันอย่างไร:

  • เส้นเชื่อมต่อหนาหมายความว่าคุณกําลังบังคับใช้ความสมบูรณ์ของข้อมูลอ้างอิง ดีจัง โดยจะซิงค์ข้อมูลของคุณอยู่เสมอ

  • ในภาพประกอบหมายเลข 1 ระบุว่าตารางนั้นสามารถมีระเบียนที่ตรงกันได้เพียงระเบียนเดียวเท่านั้น ในตารางใบสั่งซื้อที่แสดงที่นี่ จะมีเพียงระเบียนเดียวที่ตรงกับแต่ละคําสั่งซื้อ

  • สัญลักษณ์ ∞ ระบุว่าหลายระเบียนสามารถมี ID เดียวกันได้ ในตารางรายละเอียดคําสั่งซื้อที่แสดงที่นี่ คําสั่งซื้อ (ระบุโดย ID คําสั่งซื้อ) อาจปรากฏขึ้นมากกว่าหนึ่งครั้ง เนื่องจากคําสั่งซื้อเดียวกันอาจมีผลิตภัณฑ์หลายรายการ

ชนิดของความสัมพันธ์ระหว่างตาราง

ความสัมพันธ์ระหว่างตารางมีอยู่สามชนิด ดังนี้

  • แบบหนึ่ง-ต่อ-หนึ่ง เมื่อแต่ละรายการในแต่ละตารางปรากฏขึ้นเพียงครั้งเดียวเท่านั้น ตัวอย่างเช่น พนักงานแต่ละคนสามารถมีรถของบริษัทที่จะใช้ได้เพียงคันเดียวเท่านั้น สําหรับข้อมูลเพิ่มเติม ให้ดู สร้างความสัมพันธ์แบบหนึ่ง-ต่อ-หนึ่ง

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

  • กลุ่ม-ต่อ-กลุ่ม เมื่ออย่างน้อยหนึ่งรายการในตารางหนึ่งสามารถมีความสัมพันธ์กับรายการอย่างน้อยหนึ่งรายการในตารางอื่นได้ ตัวอย่างเช่น คําสั่งซื้อแต่ละรายการสามารถมีผลิตภัณฑ์ได้หลายรายการ และแต่ละผลิตภัณฑ์สามารถปรากฏบนคําสั่งซื้อหลายรายการ เมื่อต้องการค้นหาเพิ่มเติม ให้ดูที่ สร้างความสัมพันธ์แบบกลุ่ม-ต่อ-กลุ่ม

ความสัมพันธ์แบบหนึ่ง-ต่อ-กลุ่ม

หนึ่งในความสัมพันธ์ที่พบบ่อยที่สุดระหว่างตารางในฐานข้อมูลที่ออกแบบมาอย่างดีคือความสัมพันธ์แบบหนึ่ง-ต่อ-กลุ่ม

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

ในความสัมพันธ์ที่แสดงที่นี่ ตัวอย่างเช่น บุคคลแต่ละคนในตารางที่ติดต่อจะมี ID ซึ่งเป็นคีย์หลัก (ระบุโดยสัญลักษณ์คีย์ถัดจากคีย์) ID นั้นจะปรากฏในฟิลด์ เจ้าของ ในตาราง สินทรัพย์ ด้วย เมื่อต้องการส่งอีเมลถึงบุคคลที่เชื่อมโยงกับสินทรัพย์ ให้รับค่าจากเขตข้อมูล ที่อยู่อีเมล เมื่อต้องการทําเช่นนั้น ให้ค้นหาค่าในเขตข้อมูล เจ้าของ ของตาราง สินทรัพย์ แล้วค้นหา ID นั้นในตาราง ที่ติดต่อ หมายเลข 1 ที่ปลายด้านหนึ่งของเส้นเชื่อมต่อและสัญลักษณ์∞ที่ปลายอีกด้านหนึ่งระบุว่านี่คือความสัมพันธ์แบบหนึ่ง-ต่อ-กลุ่ม ดังนั้นที่ติดต่อหนึ่งรายอาจเชื่อมโยงกับสินทรัพย์จํานวนมาก

ความสัมพันธ์แบบหนึ่ง-ต่อ-กลุ่ม

การแก้ไขความสัมพันธ์

ถ้าคุณกําลังปรับเปลี่ยนฐานข้อมูลที่มีอยู่ หรือถ้าคุณสร้างฐานข้อมูลของคุณจากเทมเพลต คุณสามารถแก้ไขความสัมพันธ์ที่มีอยู่ให้ตรงกับความต้องการของคุณได้

หมายเหตุ: ถ้าตารางที่คุณต้องการทํางานด้วยถูกใช้งานอยู่ คุณต้องปิดตารางเหล่านั้นก่อน พร้อมกับวัตถุใดๆ ที่เปิดอยู่ที่ใช้ตารางเหล่านั้น

  1. เลือก เครื่องมือฐานข้อมูล > ความสัมพันธ์

  2. เลือกเส้นที่เชื่อมต่อสองตารางที่สัมพันธ์กัน

    เคล็ดลับ: ถ้าคุณไม่เห็นความสัมพันธ์ที่คุณต้องการ บนแท็บ ออกแบบ ในกลุ่ม ความสัมพันธ์ ให้เลือก ความสัมพันธ์ทั้งหมด

  3. บนแท็บ ออกแบบ ให้เลือก แก้ไขความสัมพันธ์

    การแก้ไขความสัมพันธ์ที่มีอยู่ระหว่างตาราง

    ตาราง/คิวรี เป็นตารางหลักทางด้านซ้าย (ในตัวอย่างนี้คือ ลูกค้า)

    ตาราง/คิวรีที่เกี่ยวข้อง คือตารางย่อย (ในตัวอย่างนี้ คือ ใบสั่งซื้อ)

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

  4. เมื่อต้องการเปลี่ยนเขตข้อมูลที่เชื่อมต่อตาราง ให้เลือกเขตข้อมูลที่แตกต่างกันทางด้านล่างของแต่ละตารางที่แสดง ในตัวอย่างนี้ เขตข้อมูล ID ในตารางลูกค้าจะเชื่อมต่อกับเขตข้อมูล ID ลูกค้าในตารางใบสั่งซื้อ

  5. เปลี่ยนวิธีที่ Access ซิงโครไนซ์ข้อมูลของคุณระหว่างตาราง

    บังคับให้มี Referential Integrity

    เมื่อต้องการป้องกันข้อมูลที่ไม่ถูกต้องและซิงค์การอ้างอิงระหว่างความสัมพันธ์ของตารางอยู่เสมอ ให้เลือกสิ่งนี้

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

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

    อัปเดตเขตข้อมูลที่เกี่ยวข้องทั้งหมด

    เมื่อต้องการตรวจสอบให้แน่ใจว่าข้อมูลในเขตข้อมูลที่เกี่ยวข้องได้รับการอัปเดตในตารางที่เกี่ยวข้องทั้งหมด ให้เลือกสิ่งนี้

    ตัวอย่างเช่น สมมติว่าคุณเพียงต้องการเปลี่ยน ID ของผู้จัดส่ง การตั้งค่าตัวเลือกนี้จะทําให้แน่ใจว่า ID ผู้ขนส่งสินค้าได้รับการอัปเดต ไม่ใช่ในตารางผู้ขนส่งสินค้าเท่านั้น แต่ยังรวมถึงในตารางอื่นๆ ที่เชื่อมต่อกับรหัสผู้ขนส่งสินค้าด้วย เช่น ตารางใบสั่งซื้อ

    ลบระเบียนที่เกี่ยวข้องทั้งหมด

    การตัดสินใจในการเลือกตัวเลือกนี้ขึ้นอยู่กับว่าคุณจําเป็นต้องเก็บระเบียนไว้ในบางตารางหรือไม่ แม้ว่าระเบียนเหล่านั้นอาจถูกลบออกจากตารางอื่นก็ตาม

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

  6. เมื่อต้องการเปลี่ยนความสัมพันธ์ระหว่างตารางจากการรวมภายในเป็นการรวมภายนอก ให้เลือกปุ่ม ชนิดการรวม สําหรับข้อมูลเพิ่มเติม ให้ดูที่ สร้างคิวรีด้วยการรวมภายนอก

การลบความสัมพันธ์ของตาราง

หมายเหตุ: ถ้าตารางที่คุณต้องการทํางานด้วยถูกใช้งานอยู่ คุณต้องปิดตารางเหล่านั้นก่อน พร้อมกับวัตถุใดๆ ที่เปิดอยู่ที่ใช้ตารางเหล่านั้น

เมื่อต้องการเอาความสัมพันธ์ของตารางออก ให้ทําดังนี้

  1. เลือก เครื่องมือฐานข้อมูล > ความสัมพันธ์

  2. เลือกเส้นที่เชื่อมต่อสองตารางที่สัมพันธ์กัน

    เคล็ดลับ: ถ้าคุณไม่เห็นความสัมพันธ์ที่คุณต้องการ บนแท็บ ออกแบบ ในกลุ่ม ความสัมพันธ์ ให้เลือก ความสัมพันธ์ทั้งหมด

  3. เลือกแป้น Delete ถ้าคุณได้รับพร้อมท์ให้ตรวจสอบว่าคุณต้องการลบความสัมพันธ์ ให้เลือก ใช่

หมายเหตุ: เมื่อคุณเอาความสัมพันธ์ออก คุณจะเอาการสนับสนุน Referential Integrity สําหรับความสัมพันธ์นั้นออกด้วย ถ้ามี ด้วยเหตุนี้ Access จะไม่ป้องกันการเปลี่ยนแปลงที่ส่งผลให้เกิดระเบียนที่ไม่มีเจ้าของบนหลายด้านของความสัมพันธ์แบบหนึ่ง-ต่อ-กลุ่มอีกต่อไป

ต้องการเพิ่มเติมใช่ไหม

การสร้าง แก้ไข หรือลบความสัมพันธ์

ต้องการความช่วยเหลือเพิ่มเติมหรือไม่

ต้องการตัวเลือกเพิ่มเติมหรือไม่

สํารวจสิทธิประโยชน์ของการสมัครใช้งาน เรียกดูหลักสูตรการฝึกอบรม เรียนรู้วิธีการรักษาความปลอดภัยอุปกรณ์ของคุณ และอื่นๆ

ชุมชนช่วยให้คุณถามและตอบคําถาม ให้คําติชม และรับฟังจากผู้เชี่ยวชาญที่มีความรู้มากมาย