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>