Biasanya ketika kita sedang membuat program dengan database ada situasi dimana ketika kita ingin membutuhkan lebih dari 1 perintah SQL, dimana ketika salah satu perintah SQL gagal di eksekusi maka tidak ada perintah SQL yang lainnya yang akan mengubah data pada database;
Sebagai contoh ketika ingin menyimpan data pada tabel transaksi dan detailtransaksi dengan perintah sebagai berikut
1. Insert data ke tabel transaksi
Insert transaksi (id_transaksi,tanggal) values ('TR01','2015-08-08 20:00:00')
2. Insert 2 data ke tabel detailtransaksi
Insert detailtransaksi (id_detail,id_transaksi,nama_barang,jumlah) values ('DT01','TR01','Kecap','5')
Insert detailtransaksi (id_detail,id_transaksi,nama_barang,jumlah) values ('DT02','TR01','Sambal','3')
Jika eksekusi perintah intin insert data ke tabel transaksi berhasil, dan insert 2 data ke table detailtransaksi gagal maka perintah insert data ke tabel transaksipun akan dibatalkan dan data tidak akan tersimpan ke database.
Baiklah sekarang kita akan Menggunakan Transactions di ADO.NET dengan C# dan VB.NET,
1. Buka visual studio (disini saya menggunakan visual studio community 2013) lalu buat project console applcation baru dengan nama transactionadonet
2. Tambahkan namespace System.Data.SQLClient
3. Pada void main ketikan script dibawah ini
C#
using (var conn = new SqlConnection("Data Source=(local);Initial Catalog=belajar;Persist Security Info=True;User ID=sa; Password=root"))VB.NET
{
// membuka koneksi ke database
conn.Open();
using (SqlTransaction transcation = conn.BeginTransaction())
{
try
{
// menyimpan data ke dalam tabel transaksi
using (var cmd = new SqlCommand("Insert transaksi (id_transaksi,tanggal) values ('TR01','2015-08-08 20:00:00')", conn))
{
cmd.Transaction = transcation;
cmd.ExecuteNonQuery();
Console.WriteLine("Perintah SQL 1 Berhasil Eksekusi");
}
// menyimpan data ke dalam tabel detailtransaksi
using (var cmd = new SqlCommand("Insert detailtransaksi (id_detail,id_transaksi,nama_barang,jumlah) values ('DT01','TR01','Kecap','5')", conn))
{
cmd.Transaction = transcation;
cmd.ExecuteNonQuery();
Console.WriteLine("Perintah SQL 2 Berhasil Eksekusi");
}
// menyimpan data ke dalam tabel detailtransaksi
using (var cmd = new SqlCommand("Insert detailtransaksi (id_detail,id_transaksi,nama_barang,jumlah) values ('DT02','TR01','Sambal','3')", conn))
{
cmd.Transaction = transcation;
cmd.ExecuteNonQuery();
Console.WriteLine("Perintah SQL 3 Berhasil Eksekusi");
}
transcation.Commit();
Console.WriteLine("Commit");
}
catch (SqlException ex)
{
transcation.Rollback();
Console.WriteLine("Rollback");
}
}
}
Console.ReadLine();
Using conn As SqlConnection = New SqlConnection("Data Source=(local);Initial Catalog=belajar;Persist Security Info=True;User ID=sa; Password=root")
' membuka koneksi ke database
conn.Open()
Using transcation As SqlTransaction = conn.BeginTransaction()
Try
' menyimpan data ke dalam tabel transaksi
Using cmd As SqlCommand = New SqlCommand("Insert transaksi (id_transaksi,tanggal) values ('TR01','2015-08-08 20:00:00')", conn)
cmd.Transaction = transcation
cmd.ExecuteNonQuery()
Console.WriteLine("Perintah SQL 1 Berhasil Eksekusi")
End Using
' menyimpan data ke dalam tabel detailtransaksi
Using cmd As SqlCommand = New SqlCommand("Insert detailtransaksi (id_detail,id_transaksi,nama_barang,jumlah) values ('DT01','TR01','Kecap','5')", conn)
cmd.Transaction = transcation
cmd.ExecuteNonQuery()
Console.WriteLine("Perintah SQL 2 Berhasil Eksekusi")
End Using
' menyimpan data ke dalam tabel detailtransaksi
Using cmd As SqlCommand = New SqlCommand("Insert detailtransaksi (id_detail,id_transaksi,nama_barang,jumlah) values ('DT02','TR01','Sambal','3')", conn)
cmd.Transaction = transcation
cmd.ExecuteNonQuery()
Console.WriteLine("Perintah SQL 3 Berhasil Eksekusi")
End Using
transcation.Commit()
Console.WriteLine("Commit")
Catch ex As Exception
transcation.Rollback()
Console.WriteLine("Rollback")
End Try
End Using
End Using
Console.ReadLine()
4. Jalankan program tersebut maka akan seperti gambar dibawah ini
5. Cek data pada tabel transaksi dan detail transaksi
Data brhasil ditambahkan ke tabel transaksi |
Data berhasil ditambahkan ke tabel detailtransaksi |
Insert transaksi (id_transaksi,tanggal) values ('TR01','2015-08-08 20:00:00')
7. Jalankan program kembali dengan menekan F5
kita bisa lihat pada console tersebut hanya perintah SQL 1 saja yang berhasil di eksekusi sementara lainnya gagal, naum karena kita menggunakan sqltransaction maka perintah SQL 1 akan di rollback sehingga tidak ada data baru yang tersimpan ke tabel transaksiSekian pembahasan tentang Menggunakan Transactions di ADO.NET dengan C# dan VB.NET,
Tunggu tutorial menarik lainnya, karena itu kunjungi terus blog ini
0 komentar:
Post a Comment