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
Author image

About the Author :

Nama Saya Dwi Randy Herdinanto. Saya Tinggal Di Bandar Lampung, Saat Ini SayaKuliah di Salah Satu Perguruan Tinggi di Lampung dan Juga Bekerja di Software House Lampung

Connect with me on :

2 Comments
Comments
 
Top