PDO专题(四)-PDO的事务操作

[复制链接]
查看: 85|回复: 0

585

主题

1179

帖子

6291

积分

管理员

人亦已歌

Rank: 12Rank: 12Rank: 12

积分
6291

活跃会员热心会员推广达人宣传达人突出贡献优秀版主荣誉管理论坛元老

发表于 2022-10-26 14:53:46 | 显示全部楼层 |阅读模式
事务:是一个整体,要么一起执行,要么一起回滚
事务的特性:原子性,一致性,隔离性,永久性
如要将多个SQL语句作为一个整体执行,就需要使用到事务
语法
  1. start transaction 或 begin                开启事务
  2. commit        提交事务
  3. rollback        回滚事务
复制代码
例程
  1. //创建测试数据sql代码
  2. create table bank(
  3.        cardid char(4) primary key comment '卡号',
  4.        balance decimal(10,2) not null comment '余额'
  5. )engine=innodb charset=utf8 comment '银行卡号表'

  6. insert into bank values ('1001',1000),('1002',1)
复制代码
PDO专题(四)-PDO的事务操作 PDO专题(四)-PDO的事务操作
PDO事务操作代码
  1. <body>
  2. <?php
  3. if(!empty($_POST)){
  4.     $dsn='mysql:dbname=data;charset=utf8';
  5.     $pdo=new PDO($dsn,'root','root');
  6.     $out=$_POST['card_out'];    //转出卡号
  7.     $in=$_POST['card_in'];      //注入卡号
  8.     $money=$_POST['money'];     //金额
  9.     $pdo->beginTransaction();   //开启事务
  10.     //转账
  11.     $flag1=$pdo->exec("update bank set balance=balance-$money where cardid='$out'");
  12.     $flag2=$pdo->exec("update bank set balance=balance+$money where cardid='$in'");
  13.     //查看转出的账号是否大于0,大于0返回true,否则返回false
  14.     $stmt=$pdo->query("select balance from bank where cardid='$out'");
  15.     $flag3=$stmt->fetchColumn()>=0?1:0;
  16.    
  17.     if($flag1 && $flag2 && $flag3){
  18.         $pdo->commit ();    //提交事务
  19.         echo '转账成功';
  20.     }
  21.     else{
  22.         $pdo->rollBack ();  //回滚事务
  23.         echo '转账失败';
  24.     }
  25. }
  26. ?>
  27. <form action="" method="post">
  28.     转出卡号: <input type="text" name="card_out" id=""> <br>
  29.     转入卡号: <input type="text" name="card_in" id=""> <br>
  30.     金额:<input type="text" name="money" id=""> <br>
  31.     <input type="submit" value="提交">
  32. </form>
  33. </body>
复制代码
PDO专题(四)-PDO的事务操作 PDO专题(四)-PDO的事务操作

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1、请认真发帖,禁止回复纯表情,纯数字等无意义的内容!帖子内容不要太简单!
2、提倡文明上网,净化网络环境!抵制低俗不良违法有害信息。
3、如果你对主帖作者的帖子不屑一顾的话,请勿回帖。谢谢合作!
3、问答求助区发帖求助后,如有其他用户热心帮您解决问题后,请自觉点击设为最佳答案按钮。

精彩图文
 
 
在线客服
技术支持
工作时间:
8:00-18:00
软著登字:
1361266号
官方微信扫一扫

QQ|小黑屋|慈众营销 ( 粤ICP备15049986号 )|网站地图

自动发帖软件 | 自动发帖器 | 营销推广软件 | 网络营销工具 | 网络营销软件 | 网站推广工具 | 网络推广软件 | 网络推广工具 | 网页推广软件 | 信息发布软件 | 网站推广工具 | 网页推广软件

Powered by Discuz! X3.4   © 2012-2020 Comsenz Inc.  慈众科技 - Collect from 深圳吉宝泰佛文化有限公司 公司地址:罗湖区黄贝街道深南东路集浩大厦A1403

返回顶部 返回列表