MySQLi - 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 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 pada transaksi yang dilakukan dengan sukses.

  • 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.

Di MySQL, transaksi dimulai dengan pernyataan BEGIN WORK dan diakhiri dengan pernyataan COMMIT atau ROLLBACK. Perintah SQLi 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. Ketika AUTOCOMMIT diatur ke 0, dengan mengeluarkan perintah SET AUTOCOMMIT = 0, 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 mysqli_query() fungsi.

Contoh Umum 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 mysqli_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 MySQLi

Anda tidak dapat menggunakan transaksi secara langsung, Anda dapat melakukannya tetapi tidak akan aman dan terjamin. Jika Anda berencana untuk menggunakan transaksi dalam pemrograman MySQLi 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 MySQLi dari sumber. Jika versi MySQLi Anda tidak memiliki dukungan InnoDB, minta Penyedia Layanan Internet Anda untuk membuat versi MySQLi dengan dukungan untuk jenis tabel InnoDB atau unduh dan instal distribusi biner MySQL-Max untuk Windows atau Linux / UNIX dan bekerja dengan tipe tabel di lingkungan pengembangan.

Jika instalasi MySQLi Anda mendukung tabel InnoDB, cukup tambahkan file TYPE = InnoDBdefinisi ke pernyataan pembuatan tabel. Misalnya, kode berikut membuat tabel InnoDB yang disebut tutorials_innodb -

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

mysql> use TUTORIALS;
Database changed

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

Periksa tautan berikut untuk mengetahui lebih banyak tentang - InnoDB

Anda dapat menggunakan jenis tabel lain seperti GEMINI atau BDB, tetapi itu tergantung pada penginstalan Anda jika mendukung kedua jenis ini.