Ini pada dasarnya adalah pertanyaan tentang apa itu entitas yang lemah? Kapan kita harus menggunakannya? Bagaimana mereka harus dimodelkan?
Apa perbedaan utama antara entitas normal dan entitas lemah? Apakah entitas yang lemah terkait dengan objek nilai saat melakukan Desain Berbasis Domain?
Untuk membantu menjaga pertanyaan pada topik di sini adalah contoh yang diambil dari Wikipedia yang dapat digunakan orang untuk menjawab pertanyaan ini:
Dalam contoh OrderItem
ini dimodelkan sebagai entitas yang lemah, tapi saya tidak bisa mengerti mengapa itu tidak dapat dimodelkan sebagai entitas normal.
Pertanyaan lain adalah bagaimana jika saya ingin melacak riwayat pesanan (yaitu perubahan dalam statusnya) apakah itu entitas yang normal atau lemah?
OrderItem
tergantung padaOrder
karena tidakorderItems
ada yang bisa ada tanpa menjadi milikorder
, tetapi saya tidak dapat melihat mengapa saya tidak dapat menggunakanItemLineNumber
untuk hanya mengidentifikasi item ?! Sebenarnya saya mungkin hanya membuatItemLineNumber
otomatis dihasilkanint
untuk memastikan keunikan dan menggunakan kunci asingorderID
untuk menghubungkan kedua entitas bersama ?!Sebuah
OrderItem
tidak bisa ada tanpa pesanan atau produk. Karena itu lemah karena dependensi mengendalikannya.Jika Anda misalnya menghapus pesanan Anda tidak memiliki cara untuk mengetahui di mana barang harus dikirim. Atau jika Anda menghapus produk Anda tidak tahu harus mengirim apa.
sumber
Menurut pemahaman saya dalam diagram di atas, mereka telah memasukkan dua entitas / tabel alih-alih satu yaitu pesanan dan item pesanan sehingga mengakses informasi menjadi mudah ketika dua entitas dirancang. Dan item pesanan tergantung pada entitas pesanan sehingga dianggap sebagai entitas yang lemah. karena karakteristik dari entitas yang lemah itu tergantung pada entitas yang lain. Misalkan jika Anda tidak memasukkan entitas item pesanan, bagaimana Anda dapat mengetahui harga barang pesanan, diskon. dan seperti kata jgauffin. Jika Anda misalnya menghapus pesanan, Anda tidak memiliki cara untuk mengetahui di mana barang harus dikirim. Atau jika Anda menghapus produk Anda tidak tahu harus mengirim apa.
Diagram ER harus dirancang sesuai dengan kebutuhan bisnis.
sumber
Lihat, pesanan memiliki banyak item pesanan (atribut multinilai). Jadi menurut aturan kita membuat tabel terpisah.
Sekarang, katakanlah 2 pelanggan memiliki pesanan yang sama. Baik membeli iPhone dengan harga yang sama, diskon, tanggal yang sama, dll. Jadi idealnya harus ada dua tuple yang tepat untuk urutan iPhone dalam kaitannya dengan pemesanan. Tetapi menurut batasan relasi, semua tupel harus unik. Jadi mari kita hubungkan dua pesanan ke item_line_number.no masalah yang sama uptil sekarang. Sekarang pertimbangkan salah satu pelanggan membatalkan. Apakah pesanan iPhone. Juga tuple item_line_number akan dihapus. Sekarang pelanggan lain yang membeli iPhone juga dihapus karena korespondensi M: 1. Jadi akhirnya database tidak konsisten. Itu sebabnya kami menggunakan kunci deskriptor yang akan dipesan. Menghapus satu iPhone yang dipesan tidak menyebabkan korupsi basis data.
sumber