이 기사는 주로 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='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 '转账成功!'; }else { $mysqli->rollback(); echo "转账失败!"; } $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(); ?>
데이터베이스 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 매개변수 및 데이터 필터링 그래픽 및 텍스트 자세한 설명
위 내용은 PHP 예제는 mysql 트랜잭션 처리의 사용 기술을 분석합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!