Advertisement
If you have a new account but are having problems posting or verifying your account, please email us on hello@boards.ie for help. Thanks :)
Hello all! Please ensure that you are posting a new thread or question in the appropriate forum. The Feedback forum is overwhelmed with questions that are having to be moved elsewhere. If you need help to verify your account contact hello@boards.ie
Hi all! We have been experiencing an issue on site where threads have been missing the latest postings. The platform host Vanilla are working on this issue. A workaround that has been used by some is to navigate back from 1 to 10+ pages to re-sync the thread and this will then show the latest posts. Thanks, Mike.
Hi there,
There is an issue with role permissions that is being worked on at the moment.
If you are having trouble with access or permissions on regional forums please post here to get access: https://www.boards.ie/discussion/2058365403/you-do-not-have-permission-for-that#latest

PHP/MySQLi & Transactions

  • 30-09-2013 1:53pm
    #1
    Registered Users, Registered Users 2 Posts: 1,987 ✭✭✭


    I have been playing around with running transactions with MySQLi and PHP, below is the basic format I've gotten to so far. Is there a better more standardised way to format transactions in PHP and is there a need to use $vConn->autocommit(TRUE) or does commit() set autocommit back to TRUE once it's run?

    Thanks in advance for the help/advice.
    <?php
    $vTransactionCompleted = false;
    
    // Custom class to open DB connection
    $vConn = $dbObj->open();
    
    $vConn->autocommit(FALSE);
    
    try {
    	$vConn->query("INSERT INTO Language VALUES ('DEU', 'Bavarian', 'F', 11.2)");
    	$vConn->query("INSERT INTO Language VALUES ('DEU', 'Swabian', 'F', 9.4)");
    
    	if ($vConn->commit())
    		$vTransactionCompleted = true;
    }
    catch(Exception $e)
    {
    	$vConn->rollback();
    }
    
    $vConn->autocommit(TRUE);
    
    // Custom class to close DB connection
    $dbObj->close($vConn);
    
    if ($vTransactionCompleted)
    	echo "Transaction was successful.";
    else
    	echo "Transaction failed.";
    ?>
    

    Edit: Found out one answer about setting autocommit back to TRUE, http://www.php.net/manual/en/mysqli.commit.php#89976


Advertisement