Mysql

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

Abrindo uma transação no utilizando o .

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

Por que devo sempre manter o Magento 2 atualizado?

Segurança: Atualizações frequentes geralmente incluem patches de segurança para corrigir vulnerabilidades identificadas. Ao manter o Magento atualizado, você reduz significativamente…

1 mês atrás

Adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2

Como adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2 Injete o Magento\Framework\Message\ManagerInterface no construtor da sua…

1 mês atrás

Exibir mensagens erro/sucesso da Classe: Magento\Framework\Message\ManagerInterface

Para exibir as mensagens adicionadas na classe Magento\Framework\Message\ManagerInterface em um arquivo .phtml, você pode usar o seguinte código: <?php $objectManager…

1 mês atrás

Exportar as categorias do Magento 2 em um XML

Para criar um script no Magento 2 que exporte as categorias para um arquivo XML com o nome da categoria,…

2 meses atrás

Colocar um video como Background utilizando HTML + CSS

Para definir um vídeo MP4 como plano de fundo em um <div> usando HTML e CSS, você pode seguir estas…

4 meses atrás

Desativar o “lastname” no Magento 2

Como desativar o "lastname" no Magento 2 e Adobe Commerce Desativando a obrigatoriedade do campo Execute a SQL abaixo diretamente…

4 meses atrás