Penjelasan terperinci tentang perbezaan antara kaedah .Remove() dan .DeleteObject() dalam Rangka Kerja Entiti
Dalam Rangka Kerja Entiti, terdapat dua pilihan untuk mengalih keluar item daripada pangkalan data: .Remove() dan .DeleteObject(). Walaupun kedua-dua kaedah disasarkan pada operasi pangkalan data, perbezaan halus menentukan senario terpakai mereka.
ObjectContext.DeleteObject()
ObjectContext.DeleteObject() Menandai entiti untuk dipadamkan dalam konteks. Operasi ini menetapkan EntityState entiti kepada Dipadamkan. Selepas memanggil SaveChanges, EF menghantar pernyataan SQL DELETE ke pangkalan data. Walau bagaimanapun, jika sebarang kekangan rujukan dilanggar, pengecualian akan dilemparkan, menghalang pemadaman.
EntityCollection.Remove()
EntityCollection.Remove() menandakan hubungan antara entiti induk dan entiti anak sebagai Dipadamkan. Operasi ini sendiri tidak memadamkan entiti anak secara langsung daripada pangkalan data. Bergantung pada hubungan asas, situasi berbeza akan berlaku:
Nilai pulangan dan kaedah penggunaan
.Remove() mengembalikan nilai Boolean yang menunjukkan kejayaan, manakala .DeleteObject() adalah jenis void. Pada asasnya, .Remove() mengubah suai perhubungan, manakala .DeleteObject() beroperasi secara langsung pada entiti.
Jadi, jika anda bercadang untuk memadamkan entiti terus daripada pangkalan data, gunakan .DeleteObject(). Walau bagaimanapun, jika anda ingin mengubah suai perhubungan antara entiti tanpa perlu mengalih keluar entiti anak, .Remove() adalah pilihan.
Perhatikan bahawa bahagian nota MSDN pada kaedah .Remove() agak kabur tentang kekangan integriti rujukan. Walaupun terdapat kekangan untuk ketiga-tiga jenis perhubungan, entiti anak hanya sebenarnya dipadamkan jika perhubungan itu dikenal pasti.
Atas ialah kandungan terperinci Rangka Kerja Entiti: Remove() vs. DeleteObject(): Bila Untuk Menggunakan Setiap Kaedah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!