MySQL - Transaksi

Transaksi adalah grup operasi manipulasi database yang berurutan, yang dilakukan seolah-olah itu adalah satu unit kerja tunggal. Dengan kata lain, transaksi tidak akan pernah selesai kecuali setiap operasi individu dalam grup berhasil. Jika ada operasi dalam transaksi yang gagal, seluruh transaksi akan gagal.

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 akronim ACID -

  • Atomicity- Ini 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 - Ini memastikan bahwa database dengan benar mengubah status setelah transaksi berhasil dilakukan.

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

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

Di MySQL, transaksi dimulai dengan pernyataan BEGIN WORK dan diakhiri dengan a COMMIT atau a ROLLBACKpernyataan. Perintah SQL antara pernyataan awal dan akhir membentuk sebagian besar transaksi.

COMMIT dan ROLLBACK

Dua kata kunci ini Commit dan Rollback digunakan terutama untuk Transaksi MySQL.

  • Ketika transaksi yang berhasil diselesaikan, perintah COMMIT harus dikeluarkan sehingga perubahan pada semua tabel yang terlibat akan diterapkan.

  • Jika terjadi kegagalan, perintah ROLLBACK harus dikeluarkan untuk mengembalikan setiap tabel yang direferensikan dalam transaksi ke status sebelumnya.

Anda dapat mengontrol perilaku transaksi dengan mengatur variabel sesi yang disebut AUTOCOMMIT. Jika AUTOCOMMIT diatur ke 1 (default), maka setiap pernyataan SQL (dalam transaksi atau tidak) dianggap sebagai transaksi lengkap dan dilakukan secara default saat selesai.

Saat AUTOCOMMIT diatur ke 0, dengan mengeluarkan SET AUTOCOMMIT = 0 perintah, rangkaian pernyataan berikutnya bertindak seperti transaksi dan tidak ada aktivitas yang dilakukan sampai pernyataan COMMIT eksplisit dikeluarkan.

Anda dapat menjalankan perintah SQL ini di PHP dengan menggunakan mysql_query() fungsi.

Contoh Umum tentang Transaksi

Urutan peristiwa ini tidak bergantung pada bahasa pemrograman yang digunakan. Jalur logis dapat dibuat dalam bahasa apa pun yang Anda gunakan untuk membuat aplikasi Anda.

Anda dapat menjalankan perintah SQL ini di PHP dengan menggunakan mysql_query() fungsi.

  • Mulailah transaksi dengan mengeluarkan perintah SQL BEGIN WORK.

  • Keluarkan satu atau lebih perintah SQL seperti SELECT, INSERT, UPDATE atau DELETE.

  • Periksa apakah tidak ada kesalahan dan semuanya sesuai dengan kebutuhan Anda.

  • Jika ada kesalahan apa pun, keluarkan perintah ROLLBACK, jika tidak, keluarkan perintah COMMIT.

Jenis Tabel Aman-Transaksi di MySQL

Anda tidak dapat menggunakan transaksi secara langsung, tetapi untuk pengecualian tertentu Anda bisa. Namun, mereka tidak aman dan terjamin. Jika Anda berencana untuk menggunakan transaksi dalam pemrograman MySQL Anda, maka Anda perlu membuat tabel Anda dengan cara khusus. Ada banyak jenis tabel yang mendukung transaksi, tetapi yang paling populer adalahInnoDB.

Dukungan untuk tabel InnoDB memerlukan parameter kompilasi khusus saat mengompilasi MySQL dari sumbernya. Jika versi MySQL Anda tidak memiliki dukungan InnoDB, minta Penyedia Layanan Internet Anda untuk membuat versi MySQL dengan dukungan untuk jenis tabel InnoDB atau unduh dan instalMySQL-Max Binary Distribution untuk Windows atau Linux / UNIX dan bekerja dengan tipe tabel di lingkungan pengembangan.

Jika instalasi MySQL Anda mendukung tabel InnoDB, cukup tambahkan file TYPE = InnoDB definisi ke pernyataan pembuatan tabel.

Misalnya, kode berikut membuat tabel InnoDB yang disebut tcount_tbl -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> create table tcount_tbl
   -> (
   -> tutorial_author varchar(40) NOT NULL,
   -> tutorial_count  INT
   -> ) TYPE = InnoDB;
Query OK, 0 rows affected (0.05 sec)

Untuk detail lebih lanjut tentang InnoDB, Anda dapat mengklik tautan berikut - InnoDB

Anda dapat menggunakan jenis tabel lain seperti GEMINI atau BDB, tetapi itu tergantung pada instalasi Anda, apakah itu mendukung dua tipe tabel ini atau tidak.