T-SQL - Transaksi

SEBUAH transactionadalah unit kerja yang dilakukan terhadap database. Transaksi adalah unit atau urutan pekerjaan yang diselesaikan dalam urutan logis, baik secara manual oleh pengguna atau secara otomatis oleh semacam program database.

Transaksi adalah penyebaran satu atau lebih perubahan ke database. Misalnya, jika Anda membuat catatan atau memperbarui catatan atau menghapus catatan dari tabel, maka Anda sedang melakukan transaksi di atas tabel. Penting untuk mengontrol transaksi untuk memastikan integritas data dan untuk menangani kesalahan database.

Praktisnya, Anda akan menggabungkan banyak kueri SQL ke dalam grup dan Anda akan mengeksekusi semuanya bersama sebagai bagian dari transaksi.

Sifat Transaksi

Transaksi memiliki empat sifat standar berikut, biasanya disebut dengan singkatan ACID -

  • Atomicity- Memastikan bahwa semua operasi dalam unit kerja diselesaikan dengan sukses; jika tidak, transaksi dibatalkan pada titik kegagalan, dan operasi sebelumnya digulung kembali ke keadaan semula.

  • Consistency - Memastikan bahwa database dengan benar mengubah status setelah transaksi berhasil dilakukan.

  • Isolation - Memungkinkan transaksi untuk beroperasi secara independen dan transparan satu sama lain.

  • Durability - Memastikan bahwa hasil atau efek dari transaksi yang dilakukan tetap ada jika terjadi kegagalan sistem.

Kontrol Transaksi

Ada perintah berikut yang digunakan untuk mengontrol transaksi -

  • COMMIT - Untuk menyimpan perubahan.

  • ROLLBACK - Untuk mengembalikan perubahan.

  • SAVEPOINT - Membuat poin dalam grup transaksi untuk ROLLBACK.

  • SET TRANSACTION - Menempatkan nama pada transaksi.

Perintah kontrol transaksional hanya digunakan dengan perintah DML INSERT, UPDATE dan DELETE saja. Mereka tidak dapat digunakan saat membuat tabel atau menjatuhkannya karena operasi ini secara otomatis dilakukan dalam database.

Untuk menggunakan perintah kontrol transaksional di MS SQL Server, kita harus memulai transaksi dengan 'mulai tran' atau memulai perintah transaksi jika tidak, perintah ini tidak akan berfungsi.

KOMIT KOMIT

Perintah COMMIT adalah perintah transaksional yang digunakan untuk menyimpan perubahan yang dilakukan oleh transaksi ke database. Perintah ini menyimpan semua transaksi ke database sejak perintah COMMIT atau ROLLBACK terakhir.

Sintaksis

Berikut ini adalah sintaks untuk perintah COMMIT.

COMMIT;

Contoh

Pertimbangkan tabel PELANGGAN yang memiliki catatan berikut.

ID  NAME       AGE       ADDRESS           SALARY 
1   Ramesh     32        Ahmedabad         2000.00 
2   Khilan     25        Delhi             1500.00 
3   kaushik    23        Kota              2000.00 
4   Chaitali   25        Mumbai            6500.00 
5   Hardik     27        Bhopal            8500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00

Contoh perintah berikut akan menghapus record dari tabel yang memiliki age = 25 dan kemudian COMMIT perubahan dalam database.

Begin Tran 
DELETE FROM CUSTOMERS 
   WHERE AGE = 25 
COMMIT

Akibatnya, dua baris dari tabel akan dihapus dan pernyataan SELECT akan menghasilkan keluaran sebagai berikut.

ID  NAME       AGE       ADDRESS           SALARY 
1   Ramesh     32        Ahmedabad         2000.00
3   kaushik    23        Kota              2000.00
5   Hardik     27        Bhopal            8500.00 
6   Komal      22        MP                4500.00 
7   Muffy      24        Indore            10000.00

Perintah ROLLBACK

Perintah ROLLBACK adalah perintah transaksional yang digunakan untuk membatalkan transaksi yang belum disimpan ke database. Perintah ini hanya dapat digunakan untuk membatalkan transaksi sejak perintah COMMIT atau ROLLBACK terakhir dikeluarkan.

Sintaksis

Berikut adalah sintaks untuk perintah ROLLBACK.

ROLLBACK

Contoh

Pertimbangkan tabel PELANGGAN yang memiliki catatan berikut.

ID  NAME       AGE       ADDRESS            SALARY 
1   Ramesh     32        Ahmedabad          2000.00 
2   Khilan     25        Delhi              1500.00 
3   kaushik    23        Kota               2000.00 
4   Chaitali   25        Mumbai             6500.00 
5   Hardik     27        Bhopal             8500.00 
6   Komal      22        MP                 4500.00 
7   Muffy      24        Indore             10000.00

Contoh perintah berikut akan menghapus record dari tabel yang memiliki age = 25 dan kemudian ROLLBACK perubahan dalam database.

Begin Tran 
DELETE FROM CUSTOMERS 
   WHERE AGE = 25; 
ROLLBACK

Akibatnya, operasi delete tidak akan mempengaruhi tabel dan pernyataan SELECT akan memberikan hasil sebagai berikut.

ID  NAME       AGE       ADDRESS          SALARY 
1   Ramesh     32        Ahmedabad        2000.00 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

Perintah SAVEPOINT

SAVEPOINT adalah titik dalam transaksi ketika Anda dapat mengembalikan transaksi ke titik tertentu tanpa memutar balik seluruh transaksi.

Sintaksis

Berikut ini adalah sintaks untuk perintah SAVEPOINT.

SAVE TRANSACTION SAVEPOINT_NAME

Perintah ini hanya berfungsi dalam pembuatan SAVEPOINT di antara pernyataan transaksional. Perintah ROLLBACK digunakan untuk membatalkan sekelompok transaksi.

Berikut ini adalah sintaks untuk memutar kembali ke SAVEPOINT.

ROLLBACK TO SAVEPOINT_NAME

Dalam contoh berikut, kami akan menghapus tiga catatan berbeda dari tabel PELANGGAN. Kita harus membuat SAVEPOINT sebelum setiap penghapusan, sehingga kita dapat ROLLBACK ke SAVEPOINT mana pun kapan saja untuk mengembalikan data yang sesuai ke keadaan aslinya.

Contoh

Pertimbangkan tabel CUSTOMERS yang memiliki catatan berikut -

ID  NAME       AGE       ADDRESS          SALARY 
1   Ramesh     32        Ahmedabad        2000.00 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

Berikut adalah rangkaian operasinya -

Begin Tran 
SAVE Transaction SP1 
Savepoint created. 
DELETE FROM CUSTOMERS WHERE ID = 1  
1 row deleted. 
SAVE Transaction SP2 
Savepoint created. 
DELETE FROM CUSTOMERS WHERE ID = 2 
1 row deleted.
SAVE Transaction SP3 
Savepoint created. 
DELETE FROM CUSTOMERS WHERE ID = 3 
1 row deleted.

Tiga penghapusan telah terjadi, namun, kami telah berubah pikiran dan memutuskan untuk ROLLBACK ke SAVEPOINT yang kami identifikasi sebagai SP2. Karena SP2 dibuat setelah penghapusan pertama, dua penghapusan terakhir dibatalkan -

ROLLBACK Transaction SP2 
Rollback complete.

Perhatikan bahwa hanya penghapusan pertama yang terjadi sejak kami mengembalikan ke SP2.

SELECT * FROM CUSTOMERS

6 baris dipilih.

ID  NAME       AGE       ADDRESS          SALARY 
2   Khilan     25        Delhi        1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00

ATUR Perintah TRANSAKSI

Perintah SET TRANSACTION dapat digunakan untuk memulai transaksi database. Perintah ini digunakan untuk menentukan karakteristik transaksi yang mengikuti.

Sintaksis

Berikut sintaks SET TRANSACTION.

SET TRANSACTION ISOLATION LEVEL <Isolationlevel_name>