PL / SQL - Transaksi
Pada bab ini, kita akan membahas transaksi di PL / SQL. Sebuah databasetransactionadalah unit kerja atom yang mungkin terdiri dari satu atau lebih pernyataan SQL terkait. Disebut atomic karena modifikasi basis data yang dibawa oleh pernyataan SQL yang merupakan transaksi dapat secara kolektif dilakukan, yaitu dibuat permanen ke basis data atau dibatalkan (dibatalkan) dari basis data.
Pernyataan SQL yang berhasil dieksekusi dan transaksi yang dilakukan tidak sama. Bahkan jika pernyataan SQL berhasil dieksekusi, kecuali transaksi yang berisi pernyataan tersebut dilakukan, itu dapat dibatalkan dan semua perubahan yang dibuat oleh pernyataan itu dapat dibatalkan.
Memulai dan Mengakhiri Transaksi
Sebuah transaksi memiliki a beginning dan sebuah end. Transaksi dimulai ketika salah satu dari peristiwa berikut ini terjadi -
Pernyataan SQL pertama dilakukan setelah terhubung ke database.
Pada setiap pernyataan SQL baru yang dikeluarkan setelah transaksi selesai.
Transaksi berakhir ketika salah satu dari peristiwa berikut terjadi -
SEBUAH COMMIT atau a ROLLBACK pernyataan dikeluarkan.
SEBUAH DDL pernyataan, seperti CREATE TABLEpernyataan, dikeluarkan; karena dalam kasus itu COMMIT secara otomatis dijalankan.
SEBUAH DCL pernyataan, seperti a GRANTpernyataan, dikeluarkan; karena dalam kasus itu COMMIT secara otomatis dijalankan.
Pengguna terputus dari database.
Pengguna keluar dari SQL*PLUS dengan menerbitkan EXIT perintah, COMMIT secara otomatis dilakukan.
SQL * Plus berakhir secara tidak normal, a ROLLBACK dilakukan secara otomatis.
SEBUAH DMLpernyataan gagal; dalam hal ini ROLLBACK secara otomatis dilakukan untuk membatalkan pernyataan DML tersebut.
Melakukan Transaksi
Transaksi dibuat permanen dengan mengeluarkan perintah SQL COMMIT. Sintaks umum untuk perintah COMMIT adalah -
COMMIT;
Sebagai contoh,
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (6, 'Komal', 22, 'MP', 4500.00 );
COMMIT;
Transaksi Rolling Back
Perubahan yang dibuat ke database tanpa COMMIT dapat dibatalkan menggunakan perintah ROLLBACK.
Sintaks umum untuk perintah ROLLBACK adalah -
ROLLBACK [TO SAVEPOINT < savepoint_name>];
Ketika sebuah transaksi dibatalkan karena beberapa situasi yang belum pernah terjadi sebelumnya, seperti kegagalan sistem, seluruh transaksi sejak komit secara otomatis dibatalkan. Jika Anda tidak menggunakansavepoint, lalu cukup gunakan pernyataan berikut untuk mengembalikan semua perubahan -
ROLLBACK;
Savepoints
Savepoints adalah semacam penanda yang membantu membagi transaksi panjang menjadi unit-unit yang lebih kecil dengan menetapkan beberapa pos pemeriksaan. Dengan mengatur titik simpanan dalam transaksi panjang, Anda dapat memutar kembali ke pos pemeriksaan jika diperlukan. Ini dilakukan dengan menerbitkanSAVEPOINT perintah.
Sintaks umum untuk perintah SAVEPOINT adalah -
SAVEPOINT < savepoint_name >;
Sebagai contoh
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (7, 'Rajnish', 27, 'HP', 9500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (8, 'Riddhi', 21, 'WB', 4500.00 );
SAVEPOINT sav1;
UPDATE CUSTOMERS
SET SALARY = SALARY + 1000;
ROLLBACK TO sav1;
UPDATE CUSTOMERS
SET SALARY = SALARY + 1000
WHERE ID = 7;
UPDATE CUSTOMERS
SET SALARY = SALARY + 1000
WHERE ID = 8;
COMMIT;
ROLLBACK TO sav1 - Pernyataan ini memutar kembali semua perubahan ke titik di mana Anda telah menandai savepoint sav1.
Setelah itu, perubahan baru yang Anda buat akan dimulai.
Kontrol Transaksi Otomatis
Untuk mengeksekusi a COMMIT secara otomatis setiap kali file INSERT, UPDATE atau DELETE perintah dijalankan, Anda dapat mengatur AUTOCOMMIT variabel lingkungan sebagai -
SET AUTOCOMMIT ON;
Anda dapat mematikan mode komit otomatis menggunakan perintah berikut -
SET AUTOCOMMIT OFF;