
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.
$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();
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..");
}
Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…
A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…
Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…
Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…
No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…
Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…