加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP+Mysql基于事务处理实现转账功能的方法

发布时间:2020-12-13 02:44:32 所属栏目:PHP教程 来源:网络整理
导读:《PHP+Mysql基于事务处理实现转账功能的方法》要点: 本文介绍了PHP+Mysql基于事务处理实现转账功能的方法,希望对您有用。如果有疑问,可以联系我们。 PHP应用 本篇章节讲解PHP+Mysql基于事务处理实现转账功能的办法.供大家参考研究.具体如下: ?ph

《PHP+Mysql基于事务处理实现转账功能的方法》要点:
本文介绍了PHP+Mysql基于事务处理实现转账功能的方法,希望对您有用。如果有疑问,可以联系我们。

PHP应用本篇章节讲解PHP+Mysql基于事务处理实现转账功能的办法.分享给大家供大家参考.具体如下:


<?php
  header("Content-Type:text/html;charset=utf-8");
  $mysqli=new mysqli("localhost","root","","test");
  if(mysqli_connect_errno())
  {
  printf("连接失败:%s<br>",mysqli_connect_error());
  exit();
  }
  $success=TRUE;
  $price=8000;
  $result=$mysqli->query("select cash from account where name='userA'");
  while($row=$result->fetch_assoc())
  {
  $value=$row["cash"];
  echo $value;
  }
  $mysqli->autocommit(0);
  if($value>=$price){
  $result=$mysqli->query("UPDATE account set cash=cash-$price where name='userA'");
  }else {
  echo '余额不足';
  exit();
  }
  if(!$result or $mysqli->affected_rows!=1)
  {
  $success=FALSE;
  }
  $result=$mysqli->query("UPDATE account set cash=cash+$price where name='userB'");
  if(!result or $mysqli->affected_rows!=1){
  $success=FALSE;
  }
  if($success)
  {
  $mysqli->commit();
  echo '转账成功!';
  }else
  {
  $mysqli->rollback();
  echo "转账失败!";
  }
  $mysqli->autocommit(1);
  $query="select cash from account where name=?";
  $stmt=$mysqli->prepare($query);
  $stmt->bind_param('s',$name);
  $name='userA';
  $stmt->execute();
  $stmt->store_result();
  $stmt->bind_result($cash);
  while($stmt->fetch())
  echo "用户userA的值为:".$cash;
  $mysqli->close();
?>

数据库SQL语句如下:


create table account{
 userID smallint unsigned not null auto_increment,name varchar(45) not null,cash decimal(9,2) not null,primary key(userID)
)type=InnoDB;
insert into account(name,cash) values ('userA','2000');
insert into account(name,cash) values ('userB','10000');

希望本文所述对大家的php程序设计有所赞助.

欢迎参与《PHP+Mysql基于事务处理实现转账功能的方法》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读