>백엔드 개발 >PHP 튜토리얼 >PHP 예제는 mysql 트랜잭션 처리의 사용 기술을 분석합니다.

PHP 예제는 mysql 트랜잭션 처리의 사용 기술을 분석합니다.

墨辰丷
墨辰丷원래의
2018-06-08 18:06:022021검색

이 기사는 주로 PHP 예제를 소개하고 mysql 트랜잭션 처리의 사용 기술을 분석합니다. 관심 있는 친구들이 참고할 수 있기를 바랍니다.

이 글의 예시에서는 PHP+Mysql이 트랜잭션 처리를 기반으로 전송 기능을 구현하는 방법을 설명합니다. 자세한 내용은 다음과 같습니다.

<?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();
?>

데이터베이스 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 (&#39;userA&#39;,&#39;2000&#39;);
insert into account(name,cash) values (&#39;userB&#39;,&#39;10000&#39;);

요약:위 내용은 전체 내용입니다. 이 기사의 내용이 모든 사람에게 도움이 되기를 바랍니다.

관련 권장사항:

php 매개변수 및 데이터 필터링 그래픽 및 텍스트 자세한 설명

php 중간 캐시 분류 데이터베이스 캐시

php 파일 업로드 관리 시스템

위 내용은 PHP 예제는 mysql 트랜잭션 처리의 사용 기술을 분석합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.