Abrindo uma transação no banco de dados Mysql utilizando o PHP.
Obviamente, como primeiro passo você deverá se conectar ao banco desejado.
Utilize o código a seguir:
<?php $server = 'localhost'; $user = 'root'; $pwd = ''; $db = 'mydb'; $mysqli = new mysqli($server, $user, $pwd, $db); if (mysqli_connect_errno()) trigger_error(mysqli_connect_error());
Altere as variáveis utilizadas no construtor do mysqli com os seus dados.
“Abrindo” a transação
$mysqli->autocommit(FALSE); $mysqli->query(" INSERT INTO test VALUES ('teste') "); $mysqli->query(" INSERT INTO test VALUES ('teste') "); $mysqli->commit();
Por padrão, toda a vez que a função “query” é executada o comando é enviado imediatamente para o Mysql.
Para evitar que isso aconteça, utilizados:
$mysqli->autocommit(FALSE);
Executamos os comandos desejados.
$mysqli->query(" INSERT INTO test VALUES ('teste') ");
Feito isso, realizamos o Commit:
$mysqli->commit();
Caso seja necessário, o comando de rollback:
$mysqli->rollback();
Exemplo completo
Utilizando de um bloco try/catch e statement podemos utilizar o rollback da forma correta.
No exemplo estou realizando alguns inserts, mais poderiam ser updates, selects, deletes, etc..
try { $mysqli->autocommit(false); $stmt = $mysqli->prepare("INSERT INTO `teste_0`(`col1`) VALUES (?)"); $stmt->bind_param('ss',$val1); $stmt->execute(); $stmt = $mysqli->prepare("INSERT INTO `teste_1`(`col1`) VALUES (?)"); $stmt->bind_param('ss',$val2); $stmt->execute(); $mysqli->commit(); } catch(Exception $e){ $mysqli->rollback(); throw new StorageException("Erro.."); }

