首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

phpmysql开启事务

基础概念

PHP中的MySQL事务处理是一种机制,它允许一组SQL语句作为一个单独的执行单元来执行。如果组中的所有语句都成功执行,则整个事务将被提交(commit),否则,如果任何语句失败,则整个事务将被回滚(rollback),这意味着所有更改都将被撤销。

相关优势

  1. 原子性:事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
  2. 一致性:事务必须使数据库从一个一致性状态变换到另一个一致性状态。
  3. 隔离性:事务的执行不能被其他事务干扰,即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不会互相干扰。
  4. 持久性:一旦事务提交,则其结果就是永久的,即使系统崩溃也不会丢失。

类型

MySQL支持两种类型的事务隔离级别:

  • 读未提交(Read Uncommitted)
  • 读已提交(Read Committed)
  • 可重复读(Repeatable Read)(MySQL默认)
  • 串行化(Serializable)

应用场景

事务通常用于确保数据的完整性和一致性,例如在银行转账、订单处理、库存管理等场景中。

如何开启事务

在PHP中使用MySQLi或PDO扩展可以开启事务。以下是两种方法的示例:

使用MySQLi

代码语言:txt
复制
$mysqli = new mysqli("localhost", "user", "password", "database");

if ($mysqli->connect_error) {
    die("连接失败: " . $mysqli->connect_error);
}

$mysqli->begin_transaction(); // 开启事务

try {
    $sql1 = "UPDATE accounts SET balance = balance - 100 WHERE id = 1";
    $sql2 = "UPDATE accounts SET balance = balance + 100 WHERE id = 2";

    if ($mysqli->query($sql1) === TRUE && $mysqli->query($sql2) === TRUE) {
        $mysqli->commit(); // 提交事务
        echo "转账成功";
    } else {
        $mysqli->rollback(); // 回滚事务
        echo "转账失败: " . $mysqli->error;
    }
} catch (Exception $e) {
    $mysqli->rollback();
    echo "发生异常: " . $e->getMessage();
}

$mysqli->close();

使用PDO

代码语言:txt
复制
try {
    $pdo = new PDO("mysql:host=localhost;dbname=database", "user", "password");
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    $pdo->beginTransaction(); // 开启事务

    $sql1 = "UPDATE accounts SET balance = balance - 100 WHERE id = 1";
    $sql2 = "UPDATE accounts SET balance = balance + 100 WHERE id = 2";

    $pdo->exec($sql1);
    $pdo->exec($sql2);

    $pdo->commit(); // 提交事务
    echo "转账成功";
} catch (Exception $e) {
    $pdo->rollback();
    echo "转账失败: " . $e->getMessage();
}

遇到的问题及解决方法

问题:事务没有按预期回滚

原因:可能是由于没有正确捕获异常或者没有调用rollback方法。

解决方法:确保在catch块中调用rollback方法,并检查是否有其他地方的代码提前退出了事务处理流程。

问题:事务隔离级别设置不当

原因:不同的隔离级别可能会导致不同的并发问题,如脏读、不可重复读或幻读。

解决方法:根据应用需求选择合适的隔离级别,并在事务开始前设置。

代码语言:txt
复制
$pdo->beginTransaction();
$pdo->exec("SET TRANSACTION ISOLATION LEVEL READ COMMITTED");

参考链接

请注意,以上代码示例仅供参考,实际应用中需要根据具体情况进行调整。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • springboot开启声明式事务

    前言 本小节回顾一下springboot中的声明式事务处理方式,也是实际项目中目前应用最多的一种事务处理方式,底层是基于aop来实现的 实现方式 1.在配置类上加上@EnableTransactionManagement...开启事务支持 @SpringBootApplication @EnableTransactionManagement public class DemoApplication { } 2.在service...实现类中加上@Transactional,如果该类中某个业务方法在执行时报错会进行回滚写法为:@Transactional(rollbackFor = Exception.class) 知识小结 开启注解事务管理...,等价于xml配置方式的 Spring提供了一个@EnableTransactionManagement 注解以在配置类上开启声明式事务的支持。...简单开启事务管理 事务没有回滚的可能原因 @Transactional注解修饰的函数中catch了异常,并没有往方法外抛。

    75910

    POSTGRESQL 事务控制(二) 事务开启 (写着费力,看着费劲系列)

    主要的原由是,子事务是包含在事务内的,在事务本身失效后,这些子事务也没有必要进行记录,所以在pg_wal中也不会有相关子事务的日志记录....上期说到事务的ID 只有在执行 INSERT ,UPDATE ,DELETE的时候才进行事务号的分配,那么不分配事务号的情况下,事务到底有没有事务号, 实际上是有的在事务开始时是分配一个虚拟的事务ID...process ID + 本地的计数器, 这样就可以产生一个自己的临时的虚拟的事务ID 在获取了ID后,我们直接就开始进行相关事务的开启,参加下面的语句 TRACE_POSTGRESQL_TRANSACTION_START...总结,在一个事务开启时 1 事务初始并没有实际的事务ID ,而是本地通过backend 和计数器临时分配的虚拟事务ID , 只有在事务中出现IUD 的操作才会分配实际的事务ID 2 服务器在重启或者...并且子事务与父事务之间的关系是自下而上的搜索, 只有通过子事务才能查找到自己的父事务, 并在设计的时候, 通过简单的事务ID与页面数的余数,商可以直接快速定位事务的状态.

    84351

    我现在A函数开启事务,然后调用B函数,B函数中也开启了事务

    有一点要知道,就是MYSQL不支持事务嵌套。 所以PHP再包装,也是一个事务 laravel的事务嵌套,就是一个栈。...事务A开启事务(真实开启) 事务B开启事务(只是标记,并非真实开启了事务) 事务B提交事务(只是标记,并非真的提交了事务) 事务A提交事务(真实提交) 事务A开启事务(真实开启) 事务B开启事务(只是标记...,并非真实开启了事务) 事务B提交事务(只是标记,并非真的提交了事务) 事务A回滚事务(真实回滚) 从这个栈就能看出来,只有第一次开启事务,和第一次回滚事务,和最后一次提交事务,是真实操作了数据库,其他事务操作都是假的

    44520

    ⑨【MySQL事务】事务开启、提交、回滚,事务特性ACID,脏读、幻读、不可重复读。

    事务概述 事务: 事务是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,这些操作要么同时成功,要么同时失败。...操作事务 MySQL操作事务: ①查看 / 设置事务提交方式 (@@autocommit) SELECT @@autocommit; #查看事务提交方式 SET @@autocommit = 0; #...修改事务提交方式 -- @@autocommit = 0 手动提交 -- @@autocommit = 1 自动提交 ②提交事务 COMMIT; ③回滚事务 ROLLBACK; ④提交事务 START...事务四大特性(ACID) 事务特性: 原子性(Atomicity): 事务是不可分割的最小操作单元,要么全部成功,要么全部失败。...持久性(Durability): 事务一旦提交或回滚,它对数据库数据的改变就是永久的。 4. 脏读、幻读、不可重复读 并发事务问题: ①脏读: 一个事务读到另一个事务还没有提交的数据。

    26730

    Spring 如何在一个事务中开启另一个事务?

    Spring 如何在一个事务中开启另一个事务?...这样的情景可能不常见,但是还是会有的,一旦遇到,如果业务比较复杂,就会很麻烦,但是还是有解决的方案的,比如将一个service方法拆成两个方法,也就是将两个操作的事务分开。...Spring 事务的传递性的,默认值为:required,也就是如果有事务,就加入事务,如果没有,就创建事务。...这个参数的值有很多,例如:REQUIRES_NEW,这个值就代表创建一个新的事务,与原来的事务分开。这个好像能解决我们的问题。...service中,再次测试,发现执行完插入语句之后,数据库中就已经能查到数据了,说明事务分离了,完成了我们的需求。

    76930

    如何在Windows 2008服务器上部署IIS+PHP(FastCGI)和MySQL

    后来才看见是zip,,, 解压php-7.3.32-nts-Win32-VC15-x64.zip文件,重命名文件夹为php73,把php73文件夹拷贝到指定的磁盘目录,我们在E盘目录: 打开E:\phpmysql... = 0 #开启以CGI方式运行php fastcgi.impersonate = 1 cgi.rfc2616_headers = 1 以下php扩展模块,根据需要选择开启,取消前面的分号为开始相应扩展模块...设置FastCGI,找到中间的IIS部分,打开“FastCGI设置”  右键选中“E:\phpmysql\php73\php-cgi.exe”然后选择编辑,监视对文件所做的更改:E:\phpmysql...: [mysqld] port=3306 character_set_server=utf8mb4 basedir=E:\phpmysql\mysql57 datadir=E:\phpmysql\mysql57...输入命令: cd E:\phpmysql\mysql57 进入mysql目录,然后再输入命令: mysqld --initialize-insecure 如上图所示:cmd进入bin目录下,然后执行

    52210
    领券