PHP+Mysql基于事務(wù)處理實現(xiàn)轉(zhuǎn)賬功能的方法
本文實例講述了PHP+Mysql基于事務(wù)處理實現(xiàn)轉(zhuǎn)賬功能的方法。分享給大家供大家參考。具體如下:
<?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(); ?>
數(shù)據(jù)庫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程序設(shè)計有所幫助。
相關(guān)文章
rephactor 優(yōu)秀的PHP的重構(gòu)工具
從PHP5開始,提供了強大的面向?qū)ο蠊δ?。使得PHP能夠完全按設(shè)計模式編程。2011-06-06array_multisort實現(xiàn)PHP多維數(shù)組排序示例講解
array_multisort() 可以用來一次對多個數(shù)組進行排序,或者根據(jù)某一維或多維對多維數(shù)組進行排序。2011-01-01ThinkPHP基于think-queue的隊列插件實現(xiàn)消息推送
think-queue是ThinkPHP官方提供的一個消息隊列服務(wù),是專門支持隊列服務(wù)的擴展包。think-queue消息隊列適用于大并發(fā)或返回結(jié)果時間比較長且需要批量操作的第三方接口,可用于短信發(fā)送、郵件發(fā)送、APP推送。2022-12-12解析php中die(),exit(),return的區(qū)別
本篇文章是對php中die(),exit(),return的區(qū)別進行了詳細的分析介紹,需要的朋友參考下2013-06-06使用PHP會話(Session)實現(xiàn)用戶登陸功能
本篇文章是對PHP會話(Session)實現(xiàn)用戶登陸功能進行了詳細的分析介紹,需要的朋友參考下2013-06-06通過php動態(tài)傳數(shù)據(jù)到highcharts
本文主要介紹了通過php動態(tài)傳數(shù)據(jù)到highcharts的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04