PHP实例分析了mysql事务处理的使用技巧
程序员文章站
2022-04-22 11:25:27
...
本篇文章主要介绍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实例分析了mysql事务处理的使用技巧的详细内容,更多请关注其它相关文章!
上一篇: PHP如何实现爬虫
推荐阅读
-
PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
-
php下pdo的mysql事务处理用法实例
-
基于PHP+Mysql简单实现了图书购物车系统的实例详解
-
php使用yield对性能提升的测试实例分析
-
php 函数中静态变量使用的问题实例分析
-
PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
-
PHP swoole中http_server的配置与使用方法实例分析
-
mysql中GROUP_CONCAT的使用方法实例分析
-
mysql8 公用表表达式CTE的使用方法实例分析
-
PHP的Laravel框架结合MySQL与Redis数据库的使用部署_php实例