Mysql

Mysql e PHP – Abrindo uma transação (transaction)

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/catchstatement 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..");
}

 

Resumo
Nome do Artigo
Abrindo uma transação no Mysql
Descrição
Como abrir uma transação no Mysql utilizando o PHP
Autor
Editor
Roger Mauricio Takemiya
Logo do Editor

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

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…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

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…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás