JDBC - Transaksi
Jika Koneksi JDBC Anda dalam mode komit otomatis , yang secara default, maka setiap pernyataan SQL dikomit ke database setelah selesai.
Itu mungkin bagus untuk aplikasi sederhana, tetapi ada tiga alasan mengapa Anda mungkin ingin menonaktifkan komit otomatis dan mengelola transaksi Anda sendiri -
Untuk meningkatkan kinerja.
Menjaga integritas proses bisnis.
Untuk menggunakan transaksi terdistribusi.
Transaksi memungkinkan Anda untuk mengontrol jika, dan kapan, perubahan diterapkan ke database. Ini memperlakukan satu pernyataan SQL atau sekelompok pernyataan SQL sebagai satu unit logis, dan jika ada pernyataan yang gagal, seluruh transaksi gagal.
Untuk mengaktifkan dukungan transaksi manual alih-alih mode komit otomatis yang digunakan driver JDBC secara default, gunakan objek ConnectionsetAutoCommit()metode. Jika Anda meneruskan boolean false ke setAutoCommit (), Anda menonaktifkan komit otomatis. Anda dapat mengirimkan boolean true untuk mengaktifkannya kembali.
Misalnya, jika Anda memiliki objek Connection bernama conn, kode berikut ini untuk mematikan komit otomatis -
conn.setAutoCommit(false);
Komit & Rollback
Setelah Anda selesai dengan perubahan Anda dan Anda ingin melakukan perubahan, panggil commit() metode pada objek koneksi sebagai berikut -
conn.commit( );
Jika tidak, untuk mengembalikan pembaruan ke database yang dibuat menggunakan koneksi bernama conn, gunakan kode berikut -
conn.rollback( );
Contoh berikut mengilustrasikan penggunaan objek komit dan kembalikan -
try{
//Assume a valid connection object conn
conn.setAutoCommit(false);
Statement stmt = conn.createStatement();
String SQL = "INSERT INTO Employees " +
"VALUES (106, 20, 'Rita', 'Tez')";
stmt.executeUpdate(SQL);
//Submit a malformed SQL statement that breaks
String SQL = "INSERTED IN Employees " +
"VALUES (107, 22, 'Sita', 'Singh')";
stmt.executeUpdate(SQL);
// If there is no error.
conn.commit();
}catch(SQLException se){
// If there is any error.
conn.rollback();
}
Dalam kasus ini, tidak ada pernyataan INSERT di atas yang akan berhasil dan semuanya akan dibatalkan.
Untuk pemahaman yang lebih baik, mari kita pelajari Kode Komit - Contoh .
Menggunakan Savepoints
Antarmuka JDBC 3.0 Savepoint baru memberi Anda kontrol transaksional tambahan. Kebanyakan DBMS modern, mendukung savepoints dalam lingkungan mereka seperti PL / SQL Oracle.
Saat Anda menyetel savepoint, Anda menentukan titik rollback logis dalam transaksi. Jika kesalahan terjadi setelah savepoint, Anda dapat menggunakan metode rollback untuk membatalkan semua perubahan atau hanya perubahan yang dibuat setelah savepoint.
Objek Connection memiliki dua metode baru yang membantu Anda mengelola savepoint -
setSavepoint(String savepointName):Mendefinisikan savepoint baru. Ini juga mengembalikan objek Savepoint.
releaseSavepoint(Savepoint savepointName):Menghapus savepoint. Perhatikan bahwa itu membutuhkan objek Savepoint sebagai parameter. Objek ini biasanya berupa savepoint yang dihasilkan oleh metode setSavepoint ().
ada satu rollback (String savepointName) metode, yang mengembalikan pekerjaan ke savepoint yang ditentukan.
Contoh berikut mengilustrasikan penggunaan objek Savepoint -
try{
//Assume a valid connection object conn
conn.setAutoCommit(false);
Statement stmt = conn.createStatement();
//set a Savepoint
Savepoint savepoint1 = conn.setSavepoint("Savepoint1");
String SQL = "INSERT INTO Employees " +
"VALUES (106, 20, 'Rita', 'Tez')";
stmt.executeUpdate(SQL);
//Submit a malformed SQL statement that breaks
String SQL = "INSERTED IN Employees " +
"VALUES (107, 22, 'Sita', 'Tez')";
stmt.executeUpdate(SQL);
// If there is no error, commit the changes.
conn.commit();
}catch(SQLException se){
// If there is any error.
conn.rollback(savepoint1);
}
Dalam kasus ini, tidak ada pernyataan INSERT di atas yang akan berhasil dan semuanya akan dibatalkan.
Untuk pemahaman yang lebih baik, mari kita pelajari Savepoints - Kode Contoh .