事务如何使用

事务是一个很神奇的东西  什么叫做事务呢  就是同时可以执行多个语句  一旦有一个错误 就不能运行下去 

例如我们需要做一些批量的操作并且同时执行 如果我们用其他方法 例如判断的话 那么就回一直判断 如果数据多的话 那么就有可能出错 所以我们要用一种简单的方式  开启事务  并且使用使用

简单的思路就是 开启事务  然后把要执行语句放在一起 如果一个出错那么任何都会不会往下走 并且锁定

代码如下

4.PDO事务处理
事务处理具有四个特性:原子性、一致性、独立性、持久性。
        并不是所有的数据库都支持事务处理的,PDO 为能够执行事务处理的数据库提供事务支持。
        配置事务处理需注意:
        关闭 PDO 的自动提交;
    $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, false);  
      开启一个事务需要的方法;
    $pdo->beginTransaction(); // 开启一个事务  
    $pdo->commit(); // 提交事务  
    $pdo->rollback(); // 回滚事务  
        一般事务处理是运行在 try...catch...语句中,当事务失败时执行 catch 代码段。
    <?php  
    try {  
        $pdo->beginTransaction(); // 开启一个事务  
        $row = null;  
        $row = $pdo->exec("xxx"); // 执行第一个 SQL  
        if (!$row)   
            throw new PDOException('提示信息或执行动作'); // 如出现异常提示信息或执行动作  
        $row = $pdo->exec("xxx"); // 执行第二个 SQL  
        if (!$row)   
            throw new PDOException('提示信息或执行动作');  
        $pdo->commit();  
    } catch (PDOException $e) {  
        $pdo->rollback(); // 执行失败,事务回滚  
        exit($e->getMessage());  
    }  
    ?>  
        在事务中的 SQL 语句,如果出现错误,那么所有的 SQL 都不执行。当所有 SQL 有无误的时候,才提交执行。


这是开启事务的方式 

还有一个例子

<?php
header("content-type:text/html;charset=utf-8");
$db = new mysqli("127.0.0.1","root","root","demo"); //连接数据库

$db->autocommit(false); //设置为非自动提交——事务处理

$sql1  = "update test set t_price=t_price-5 where t_name='小王'";

$result1 = $db->query($sql1);

$sql2  = "update test set t_price=t_price+2 where t_name='小明'";

$result2 = $db->query($sql2);

$sql3  = "update test set t_price=t_price+3 where t_name='小李'";

$result3 = $db->query($sql3);

if ($result1 && $result2 && $result3) {

    $db->commit();  //全部成功,提交执行结果

    echo '转账成功';

} else {

    $db->rollback(); //有任何错误发生,回滚并取消执行结果

    echo '回滚';

}

$db->autocommit(true); //设置为非自动提交——事务处理

$db->close();

?>

只供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值