PHP+Mysql基于事务处理实现转账功能的方法
发布时间:2020-12-13 02:44:32 所属栏目:PHP教程 来源:网络整理
导读:《PHP+Mysql基于事务处理实现转账功能的方法》要点: 本文介绍了PHP+Mysql基于事务处理实现转账功能的方法,希望对您有用。如果有疑问,可以联系我们。 PHP应用 本篇章节讲解PHP+Mysql基于事务处理实现转账功能的办法.供大家参考研究.具体如下: ?ph
《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为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |