MySQL事务是一组原子性的SQL操作序列,这些操作要么全部成功执行,要么全部失败回滚,事务具有ACID特性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability),在实际应用中,事务常用于实现数据的完整性和一致性。
创新互联建站专业为企业提供大关网站建设、大关做网站、大关网站设计、大关网站制作等企业网站建设、网页设计与制作、大关企业网站模板建站服务,十年大关做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
下面通过一个实例来详细介绍如何使用MySQL事务。
假设我们有一个在线购物网站,用户可以在网站上购买商品,在用户下单时,需要对库存表进行减操作,同时在订单表中插入一条记录,这两个操作需要作为一个整体来执行,要么都成功,要么都失败,为了实现这个需求,我们可以使用MySQL事务。
1、创建数据库和表
我们需要创建一个数据库和一个库存表,用于存储商品的库存信息。
CREATE DATABASE online_shopping; USE online_shopping; CREATE TABLE inventory ( id INT PRIMARY KEY AUTO_INCREMENT, product_id INT NOT NULL, quantity INT NOT NULL ); INSERT INTO inventory (product_id, quantity) VALUES (1, 100); INSERT INTO inventory (product_id, quantity) VALUES (2, 200); INSERT INTO inventory (product_id, quantity) VALUES (3, 300);
接下来,我们创建一个订单表,用于存储用户的订单信息。
CREATE TABLE orders ( id INT PRIMARY KEY AUTO_INCREMENT, user_id INT NOT NULL, product_id INT NOT NULL, quantity INT NOT NULL, order_time DATETIME NOT NULL );
2、编写事务处理程序
在PHP中,我们可以使用mysqli扩展来实现MySQL事务,以下是一个简单的示例:
connect_error) { die("连接失败: " . $conn>connect_error); } // 开始事务 $conn>begin_transaction(); try { // 减少库存数量 $stmt1 = $conn>prepare("UPDATE inventory SET quantity = quantity ? WHERE product_id = ?"); $stmt1>bind_param("ii", $quantity, $product_id); $quantity = 1; // 购买数量 $product_id = 1; // 购买商品ID $stmt1>execute(); // 插入订单记录 $stmt2 = $conn>prepare("INSERT INTO orders (user_id, product_id, quantity, order_time) VALUES (?, ?, ?, NOW())"); $stmt2>bind_param("iii", $user_id, $product_id, $quantity); $user_id = 1; // 用户ID $stmt2>execute(); // 如果以上两个操作都成功,则提交事务;否则回滚事务。 if ($stmt1>affected_rows > 0 && $stmt2>affected_rows > 0) { $conn>commit(); echo "购买成功!"; } else { $conn>rollback(); echo "购买失败!"; } } catch (Exception $e) { // 如果发生异常,回滚事务。 $conn>rollback(); echo "购买失败!"; } finally { // 关闭连接。 $stmt1>close(); $stmt2>close(); $conn>close(); } ?>
在这个示例中,我们首先创建了一个连接到MySQL数据库的连接对象,我们使用begin_transaction()
方法开始一个新的事务,接下来,我们编写了两个SQL语句,分别用于减少库存数量和插入订单记录,这两个操作需要作为一个整体来执行,要么都成功,要么都失败,我们将它们放在一个try
块中,如果这两个操作都成功执行,则使用commit()
方法提交事务;否则,使用rollback()
方法回滚事务,我们关闭了与数据库的连接。
分享标题:MySQL事务实例分享
文章来源:http://www.mswzjz.cn/qtweb/news5/173155.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能