Lompat ke konten Lompat ke sidebar Lompat ke footer

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

Posting Komentar untuk "Menggunakan Transactions di ADO.NET dengan C# dan VB.NET"