Setelah selesai melakukan mapping, baik secara manual atau menggunakan tool seperti ADO.NET Entity Data Model Designer dan Entity Framework Power Tools, kita bisa langsung mencoba method-method dasar aplikasi database yang dikenal dengan istilah method CRUD seperti Save, Update, Delete dan Get.
Ingat tujuan kita menggunakan ORM seperti Entity Framework dalam pengembangan aplikasi database adalah agar kita tidak lagi berhubungan secara langsung dengan database berikut objek-objeknya seperti tabel, view dan objek database lainnya, sehingga bisa lebih fokus ke aturan bisnis dari aplikasi yang sedang dikembangkan.
Dalam paradigma OOP, semuanya adalah objek. Saya, Anda, Customer, Supplier, Product adalah objek.
Ada beberapa keuntungan yang kita dapatkan ketika berhubungan dengan class dan objek :
Persistence ignorance - Kita tidak perlu lagi khawatir bagaimana data disimpan ataupun media yang digunakan.
Strong typing - Kita tidak perlu lagi melakukan konversi secara manual untuk setiap tipe data kolom/field yang ada di dalam sebuah tabel ketika ingin mengambil nilainya.
Compile-time checking - Class mempunyai daftar property, jika kita mengetikkan nama property yang salah, secara langsung akan mendapatkan kompilasi error. Sehingga tidak perlu menjalankan aplikasi untuk mengetahui kesalahan penulisan kode.
Ease of development - Editor kode seperti Visual Studio mempunyai fitur IntelliSense untuk mempercepat proses pengembangan aplikasi. IntelliSense memberikan petunjuk kepada pengembang aplikasi tentang daftar property, event dan method yang dimiliki oleh sebuah class. Tetapi jika kita menggunakan DataSet atau DataReader, fitur IntelliSense jadi tidak berfungsi karena penulisan nama field/kolom berbasis teks (string).
Di bawah ini kita akan membandingkan pembuatan method-method CRUD menggunakan library ADO.NET secara langsung dan menggunakan Entity Framework.
Adapun sebagai targetnya adalah tabel Supplier yang diwakili oleh class Supplier.
1. Save - Untuk menambahkan data baru
ADO.NET
123456789101112131415161718192021
privatestaticintSaveUsingADONET(Suppliersupplier){varresult=0;using(varconn=GetOpenConnection()){varsql=@"INSERT INTO Supplier (NamaSupplier, Jalan, Kota) VALUES (@1, @2, @3)";using(varcmd=newSqlCommand(sql,conn)){cmd.Parameters.AddWithValue("@1",supplier.NamaSupplier);cmd.Parameters.AddWithValue("@2",supplier.Jalan);cmd.Parameters.AddWithValue("@3",supplier.Kota);result=cmd.ExecuteNonQuery();}}returnresult;}
Dari dua method di atas, kita bisa melihat bahwa method Save menggunakan Entity Framework (EF) lebih sederhana sehingga mengurangi kesalahan dalam penulisan kode dibandingkan dengan menggunakan ADO.NET secara langsung. Kita tidak lagi menuliskan perintah SQL INSERT yang masih berbasis teks (string).
Contoh penggunaan :
12345678910
// buat objek suppliervarsupplier=newSupplier{NamaSupplier="Morgan Bike Accessories",Jalan="6387 Scenic Avenue",Kota="Bothell"};varresult1=SaveUsingADONET(supplier);varresult2=SaveUsingEF(supplier);
2. Update - Untuk mengupdate data
ADO.NET
12345678910111213141516171819202122
privatestaticintUpdateUsingADONET(Suppliersupplier){varresult=0;using(varconn=GetOpenConnection()){varsql=@"UPDATE Supplier SET NamaSupplier = @1, Jalan = @2, Kota = @3 WHERE SupplierID = @4";using(varcmd=newSqlCommand(sql,conn)){cmd.Parameters.AddWithValue("@1",supplier.NamaSupplier);cmd.Parameters.AddWithValue("@2",supplier.Jalan);cmd.Parameters.AddWithValue("@3",supplier.Kota);cmd.Parameters.AddWithValue("@4",supplier.SupplierID);result=cmd.ExecuteNonQuery();}}returnresult;}
// buat objek suppliervarsupplier=newSupplier{SupplierID=34,NamaSupplier="Morgan Bike Accessories",Jalan="6387 Scenic Avenue",Kota="Bothell"};varresult1=UpdateUsingADONET(supplier);varresult2=UpdateUsingEF(supplier);
3. Delete - Untuk menghapus data
ADO.NET
12345678910111213141516171819
privatestaticintDeleteUsingADONET(Suppliersupplier){varresult=0;using(varconn=GetOpenConnection()){varsql=@"DELETE FROM Supplier WHERE SupplierID = @1";using(varcmd=newSqlCommand(sql,conn)){cmd.Parameters.AddWithValue("@1",supplier.SupplierID);result=cmd.ExecuteNonQuery();}}returnresult;}
// buat objek suppliervarsupplier=newSupplier{SupplierID=34};varresult1=DeleteUsingADONET(supplier);varresult2=DeleteUsingEF(supplier);
4. GetAll - Untuk menampilkan semua data
Method ini akan mengembalikan kumpulan objek supplier, karena objek suppliernya bisa lebih dari satu maka dibutuhkan sebuah wadah (container) untuk menampung kumpulan objek supplier.
Untuk contoh di bawah ini saya menggunakan objek List untuk menampung kumpulan objek supplier.
privatestaticIList<Supplier>GetAllUsingADONET(){vardaftarSupplier=newList<Supplier>();using(varconn=GetOpenConnection()){varsql=@"SELECT SupplierID, NamaSupplier, Jalan, Kota FROM Supplier ORDER BY NamaSupplier";using(varcmd=newSqlCommand(sql,conn)){using(vardtr=cmd.ExecuteReader()){while(dtr.Read()){varsupplier=newSupplier{SupplierID=dtr["SupplierID"]isDBNull?0:(int)dtr["SupplierID"],NamaSupplier=dtr["NamaSupplier"]isDBNull?string.Empty:(string)dtr["NamaSupplier"],Jalan=dtr["Jalan"]isDBNull?string.Empty:(string)dtr["Jalan"],Kota=dtr["Kota"]isDBNull?string.Empty:(string)dtr["Kota"]};daftarSupplier.Add(supplier);}}}}returndaftarSupplier;}
privatestaticIList<Supplier>GetByNameUsingADONET(stringnamaSupplier){vardaftarSupplier=newList<Supplier>();using(varconn=GetOpenConnection()){varsql=@"SELECT SupplierID, NamaSupplier, Jalan, Kota FROM Supplier WHERE NamaSupplier LIKE @1 ORDER BY NamaSupplier";using(varcmd=newSqlCommand(sql,conn)){cmd.Parameters.AddWithValue("@1","%"+namaSupplier+"%");using(vardtr=cmd.ExecuteReader()){while(dtr.Read()){varsupplier=newSupplier{SupplierID=dtr["SupplierID"]isDBNull?0:(int)dtr["SupplierID"],NamaSupplier=dtr["NamaSupplier"]isDBNull?string.Empty:(string)dtr["NamaSupplier"],Jalan=dtr["Jalan"]isDBNull?string.Empty:(string)dtr["Jalan"],Kota=dtr["Kota"]isDBNull?string.Empty:(string)dtr["Kota"]};daftarSupplier.Add(supplier);}}}}returndaftarSupplier;}
privatestaticSupplierGetByIDUsingADONET(intsupplierID){Suppliersupplier=null;using(varconn=GetOpenConnection()){varsql=@"SELECT SupplierID, NamaSupplier, Jalan, Kota FROM Supplier WHERE SupplierID = @1";using(varcmd=newSqlCommand(sql,conn)){cmd.Parameters.AddWithValue("@1",supplierID);using(vardtr=cmd.ExecuteReader()){if(dtr.Read()){supplier=newSupplier();supplier.SupplierID=dtr["SupplierID"]isDBNull?0:(int)dtr["SupplierID"];supplier.NamaSupplier=dtr["NamaSupplier"]isDBNull?string.Empty:(string)dtr["NamaSupplier"];supplier.Jalan=dtr["Jalan"]isDBNull?string.Empty:(string)dtr["Jalan"];supplier.Kota=dtr["Kota"]isDBNull?string.Empty:(string)dtr["Kota"];}}}}returnsupplier;}
Semua contoh method di atas masih menggunakan access modifier private static karena saya melakukan testingnya langsung di method Main (static void Main). Idealnya semua method di atas disimpan di dalam sebuah class dengan access modifier public.
Dan kesimpulan akhirnya adalah, dengan menggunakan ORM seperti Entity Framework, kita bisa dengan mudah membuat standarisasi penulisan kode untuk mengakses database karena memiliki pola yang sama, yg membedakan hanya nilai Statenya saja.