PHP+Mysql基于事务处理实现转账功能的方法
本文实例讲述了PHP+Mysql基于事务处理实现转账功能的方法。分享给大家供大家参考。具体如下:
<?php
header("Content-Type:text/html;charset=utf-8");
$mysqli=newmysqli("localhost","root","","test");
if(mysqli_connect_errno())
{
printf("连接失败:%s<br>",mysqli_connect_error());
exit();
}
$success=TRUE;
$price=8000;
$result=$mysqli->query("selectcashfromaccountwherename='userA'");
while($row=$result->fetch_assoc())
{
$value=$row["cash"];
echo$value;
}
$mysqli->autocommit(0);
if($value>=$price){
$result=$mysqli->query("UPDATEaccountsetcash=cash-$pricewherename='userA'");
}else{
echo'余额不足';
exit();
}
if(!$resultor$mysqli->affected_rows!=1)
{
$success=FALSE;
}
$result=$mysqli->query("UPDATEaccountsetcash=cash+$pricewherename='userB'");
if(!resultor$mysqli->affected_rows!=1){
$success=FALSE;
}
if($success)
{
$mysqli->commit();
echo'转账成功!';
}else
{
$mysqli->rollback();
echo"转账失败!";
}
$mysqli->autocommit(1);
$query="selectcashfromaccountwherename=?";
$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语句如下:
createtableaccount{
userIDsmallintunsignednotnullauto_increment,
namevarchar(45)notnull,
cashdecimal(9,2)notnull,
primarykey(userID)
)type=InnoDB;
insertintoaccount(name,cash)values('userA','2000');
insertintoaccount(name,cash)values('userB','10000');
希望本文所述对大家的php程序设计有所帮助。
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短