Minggu, 09 Agustus 2015

Menggunakan Transactions di ADO.NET dengan C# dan VB.NET

INDONESIANWARE - Pada Artikel yang anda baca kali ini dengan judul Menggunakan Transactions di ADO.NET dengan C# dan VB.NET, kami telah mempersiapkan artikel ini dengan baik untuk anda baca dan ambil informasi didalamnya. mudah-mudahan isi postingan Artikel Tutorial C#, Artikel Tutorial VB.Net, yang kami tulis ini dapat anda pahami. baiklah, selamat membaca.

Judul : Menggunakan Transactions di ADO.NET dengan C# dan VB.NET
link : Menggunakan Transactions di ADO.NET dengan C# dan VB.NET

Baca juga


Menggunakan Transactions di ADO.NET dengan C# dan VB.NET

Assalamualaikum agan semua, maaf karena sudah lumayan lama tidak posting :D, dikarenakan menyibukan diri :D, pada malam hari ini saya ingin memposting tutorial tentang Menggunakan Transactions di ADO.NET dengan C# dan VB.NET,

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

Menggunakan Transactions di ADO.NET dengan C# dan VB.NET

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"))
{
// 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();
VB.NET
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

Menggunakan Transactions di ADO.NET dengan C# dan VB.NET

5. Cek data pada tabel transaksi dan detail transaksi

Menggunakan Transactions di ADO.NET dengan C# dan VB.NET
Data brhasil ditambahkan ke tabel transaksi


Menggunakan Transactions di ADO.NET dengan C# dan VB.NET
Data berhasil ditambahkan ke tabel detailtransaksi
6. sekarang kita coba ubah perintah insert tabel transaksi menjadi
Insert transaksi (id_transaksi,tanggal) values ('TR01','2015-08-08 20:00:00')

7. Jalankan program kembali dengan menekan F5

Menggunakan Transactions di ADO.NET dengan C# dan VB.NET
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 transaksi
Sekian pembahasan tentang Menggunakan Transactions di ADO.NET dengan C# dan VB.NET,
Tunggu tutorial menarik lainnya, karena itu kunjungi terus blog ini


Sekianlah artikel Menggunakan Transactions di ADO.NET dengan C# dan VB.NET kali ini, mudah-mudahan bisa memberi manfaat untuk anda semua. baiklah, sampai jumpa di postingan artikel lainnya.

Anda sekarang membaca artikel Menggunakan Transactions di ADO.NET dengan C# dan VB.NET dengan alamat link https://ware-id.blogspot.com/2015/08/menggunakan-transactions-di-adonet.html


EmoticonEmoticon