温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-01-29 16:19:33 来源:亿速云 阅读:220 作者:Leah 栏目:开发技术

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

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI