Heim > Backend-Entwicklung > PHP-Tutorial > php事务处理实例详解_PHP教程

php事务处理实例详解_PHP教程

WBOY
Freigeben: 2016-07-13 10:23:50
Original
958 Leute haben es durchsucht

php事务处理实例详解

   一、php事务处理概述:

  事务:是若干事件的集合

  事务处理:当所有事件执行成功,事务才执行;若有任何一个事件不能成功执行,事务的其它事件也不被执行。

  只要你的MySQL版本支持BDB或InnoDB表类型,那么你的MySQL就具有事务处理的能力。这里面,又以InnoDB表类型用的最多,虽然后来发生了诸如Oracle收购InnoDB等令MySQL不爽的事情,但是这类商业事件与技术无关,下面就以InnoDB表类型为例简单说一下MySQL中的事务处理。

  二、php事务处理代码:

  

  try{

  $pdo=new PDO("mysql:host=localhost;dbname=psp","root","");

  $pdo->exec("set names utf8");

  $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//设置异常处理模式

  $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);//关闭自动提交

  }catch(PDOException $e){

  echo "数据库连接失败";

  exit;

  }

  try{

  $age=10;

  $pdo->beginTransaction();//开始事务

  $affected_rows1=$pdo->exec("update kfry set k_age=k_age+{$age} where k_name='user1'");

  $affected_rows2=$pdo->exec("update kfry set k_age=k_age-{$age} where k_name='user2'");//随意更改使之执行成功或失败

  /* if($affected_rows1&&$affected_rows2)

  {

  $pdo->commit();

  echo "操作成功";

  }else{

  $pdo->rollback();

  } */

  if(!$affected_rows1)

  throw new PDOException("加入错误");

  if(!$affected_rows2)

  throw new PDOException("减少错误");

  echo "操作成功";

  $pdo->commit();//如果执行到此处前面两个更新sql语句执行成功,整个事务执行成功

  }catch(PDOException $e){

  echo "操作失败:".$e->getMessage();

  $pdo->rollback();//执行事务中的语句出了问题,整个事务全部撤销

  }

  $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);

  //测试是否成功

  echo "\n操作结果为:\n";

  $sql="select * from kfry";

  $result=$pdo->query($sql);

  foreach($result as $v)

  {

  echo $v['k_name']." ".$v['k_age']."\n";

  }

  ?>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/834954.htmlTechArticlephp事务处理实例详解 一、php事务处理概述: 事务:是若干事件的集合 事务处理:当所有事件执行成功,事务才执行;若有任何一个事件不能成功...
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage