ホームページ >バックエンド開発 >PHPチュートリアル >Mysqlトランザクション処理(転送プログラム)

Mysqlトランザクション処理(転送プログラム)

WBOY
WBOYオリジナル
2016-07-25 09:01:301205ブラウズ
  1. header("Content-Type:text/html;charset=utf-8");
  2. $mysqli=new mysqli("localhost","root","","test") ;
  3. if(mysqli_connect_errno())
  4. {
  5. printf("接続失敗:%s
    ",mysqli_connect_error());
  6. exit();
  7. }
  8. $success=TRUE;
  9. $price=8000;
  10. $result=$mysqli->query("name='userA' のアカウントから現金を選択");
  11. while($row=$result->fetch_assoc())
  12. {
  13. $value=$row["cash "];
  14. echo $value;
  15. }
  16. $mysqli->autocommit(0);
  17. if($value>=$price){
  18. $result=$mysqli->query("UPDATE アカウント セット キャッシュ = キャッシュ-$price where name='userA'");
  19. }else {
  20. echo '余额不足';
  21. exit();
  22. }
  23. if(!$result or $mysqli->affected_rows!=1)
  24. {
  25. $success=FALSE;
  26. }
  27. $result=$mysqli->query("UPDATE account setCash=cash+$price where name='userB'");
  28. if(!result or $mysqli->affected_rows! =1){
  29. $success=FALSE;
  30. }
  31. if($success)
  32. {
  33. $mysqli->commit();
  34. echo '转账成功!';
  35. }else
  36. {
  37. $mysqli-> rollback();
  38. echo "转账失败!";
  39. }
  40. $mysqli->autocommit(1);
  41. $query="name=? のアカウントから現金を選択";
  42. $stmt=$mysqli->prepare ($query);
  43. $stmt->bind_param('s',$name);
  44. $name='userA';
  45. $stmt->execute();
  46. $stmt->store_result();
  47. $stmt->bind_result($cash);
  48. while($stmt->fetch())
  49. echo "用户userAの值:".$cash;
  50. $mysqli->close();
  51. ? >
  52. &&&&&&&&&&&&&&&&&
  53. テーブルアカウントを作成します{
  54. userID smallint unsigned not null auto_increment,
  55. name varchar(45) not null,
  56. Cash Decimal(9,2) not null,
  57. 主キー(userID)
  58. )type =InnoDB;
  59. account(name,cash) の値 ('userA','2000') に挿入;
  60. account(name,cash) の値 ('userB','10000');
复制代码


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。