Ekstensi mysql lama tidak memiliki fungsi khusus untuk kontrol transaksi, tetapi Anda dapat mengeluarkan pernyataan SQL untuk melakukan apa yang Anda inginkan.
Anda dapat menonaktifkan autocommit secara implisit selama satu transaksi hanya dengan memulai transaksi:
mysql_query("START TRANSACTION");
Segera setelah Anda COMMIT atau ROLLBACK, mode autocommit akan kembali ke default.
mysql_query("COMMIT"); // or ROLLBACK
Anda dapat menonaktifkan komit otomatis untuk seluruh sesi dengan menyetel variabel sesi:
mysql_query("SET autocommit=0");
Atau ubah secara global pada instance MySQL Anda sehingga mengubah default untuk semua sesi:
mysql_query("SET GLOBAL autocommit=0");
Atau atur untuk mengubah pengaturan global saat memulai layanan MySQL dengan mengedit /etc/my.cnf:
[mysqld]
autocommit=0
Jika Anda menggunakan MySQL 5.1, Anda harus melakukannya sedikit berbeda:
[mysqld]
init_connect='SET autocommit=0'
Anda mungkin sudah tahu, tetapi perlu diulang bahwa transaksi hanya berarti apa-apa jika Anda menggunakan tabel InnoDB. Tabel MyISAM tidak mendukung transaksi, jadi mereka selalu melakukan autocommit terlepas dari pengaturan Anda. Sama dengan beberapa mesin penyimpanan lainnya, termasuk MEMORY dan CSV.