《PHP教程:PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的方法》要點(diǎn):
本文介紹了PHP教程:PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的方法,希望對(duì)您有用。如果有疑問,可以聯(lián)系我們。
PHP應(yīng)用本文實(shí)例講述了PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的辦法.分享給大家供大家參考.具體如下:
PHP應(yīng)用
<?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 '轉(zhuǎn)賬成功!';
}else
{
$mysqli->rollback();
echo "轉(zhuǎn)賬失敗!";
}
$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();
?>
PHP應(yīng)用數(shù)據(jù)庫(kù)SQL語句如下:
PHP應(yīng)用
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應(yīng)用希望本文所述對(duì)大家的php程序設(shè)計(jì)有所贊助.
歡迎參與《PHP教程:PHP+Mysql基于事務(wù)處理實(shí)現(xiàn)轉(zhuǎn)賬功能的方法》討論,分享您的想法,維易PHP學(xué)院為您提供專業(yè)教程。
轉(zhuǎn)載請(qǐng)注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/9719.html