加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > PHP > 正文

PHP + MySQL事务实例讲解

发布时间:2020-05-25 02:32:31 所属栏目:PHP 来源:互联网
导读:本文章向大家介绍PHP + MySQL事务示例,需要的朋友可以参考一下。

我在处理事务时通常使用的想法如下(半伪代码):

try {

// First of all,let's begin a transaction

$db->beginTransaction();

// A set of queries; if one fails,an exception should be thrown

$db->query('first query');

$db->query('second query');

$db->query('third query');

// If we arrive here,it means that no exception was thrown

// i.e. no query has failed,and we can commit the transaction

$db->commit();

} catch (Exception $e) {

// An exception has been thrown

// We must rollback the transaction

$db->rollback();

}


请注意,有了这个想法,如果查询失败,则必须抛出异常:

PDO可以这样做,具体取决于您的配置方式

看到PDO::setAttribute

并PDO::ATTR_ERRMODE与PDO::ERRMODE_EXCEPTION

否则,使用其他API,您可能必须测试用于执行查询的函数的结果,并自己抛出异常。


不幸的是,没有任何魔法涉及。您不能只是在某处放置指令并自动完成事务:您仍然必须具体必须在事务中执行哪组查询。

例如,通常在事务之前(在之前begin)和事务之后的另外几个查询(在commit或之后rollback)会有几个查询,并且无论发生了什么(或不发生),您都希望执行这些查询

再来一个php+mysql事物实例:

// trans.php

function begin(){

mysql_query("BEGIN");

}

function commit(){

mysql_query("COMMIT");

}

function rollback(){

mysql_query("ROLLBACK");

}

mysql_connect("localhost","Dude1","SuperSecret") or die(mysql_error());

mysql_select_db("bedrock") or die(mysql_error());

$query = "INSERT INTO employee (ssn,name,phone) values ('123-45-6789','Matt','1-800-555-1212')";

begin(); // transaction begins

$result = mysql_query($query);

if(!$result){

rollback(); // transaction rolls back

echo "transaction rolled back";

exit;

}else{

commit(); // transaction is committed

echo "Database transaction was successful";

}

?>

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读