C语言学习网

怎么在PHP中利用Mysql事务处理实现一个转账功能

发表于:2023-03-24 作者:安全数据网编辑
编辑最后更新 2023年03月24日,今天就跟大家聊聊有关怎么在PHP中利用Mysql事务处理实现一个转账功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体如下:

今天就跟大家聊聊有关怎么在PHP中利用Mysql事务处理实现一个转账功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

具体如下:

",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中利用Mysql事务处理实现一个转账功能有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注行业资讯频道,感谢大家的支持。

0