> php教程 > PHP源码 > Mysql事务处理(一个转账程序) - PHP

Mysql事务处理(一个转账程序) - PHP

PHP中文网
풀어 주다: 2016-05-25 17:02:21
원래의
2693명이 탐색했습니다.

php代码

<?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=&#39;userA&#39;");
     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=&#39;userA&#39;");
     }else {
        echo &#39;余额不足&#39;;
        exit();
     }
     if(!$result or $mysqli->affected_rows!=1)
     {
        $success=FALSE;
     }
       
     $result=$mysqli->query("UPDATE account set cash=cash+$price where name=&#39;userB&#39;");
     if(!result or $mysqli->affected_rows!=1){
        $success=FALSE;
     }
       
     if($success)
     {
        $mysqli->commit();
        echo &#39;转账成功!&#39;;
     }else
     {
        $mysqli->rollback();
        echo "转账失败!";
     }
     $mysqli->autocommit(1);
     $query="select cash from account where name=?";
     $stmt=$mysqli->prepare($query);
     $stmt->bind_param(&#39;s&#39;,$name);
     $name=&#39;userA&#39;;
     $stmt->execute();
     $stmt->store_result();
     $stmt->bind_result($cash);
     while($stmt->fetch())
     echo "用户userA的值为:".$cash;
       
     $mysqli->close();
?>
 
 
 
&&&&&&&&&&&&&&&&&&
 
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 (&#39;userA&#39;,&#39;2000&#39;);
insert into account(name,cash) values (&#39;userB&#39;,&#39;10000&#39;);
로그인 후 복사
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿