>백엔드 개발 >PHP 튜토리얼 >PHP Mysql Transaction

PHP Mysql Transaction

WBOY
WBOY원래의
2016-06-23 14:36:16911검색

在PHP中,mysqli 已经很好的封装了mysql事务的相关操作。如下示例:

view plain copy to clipboard print ?

$sql1 = "update User set ScoreCount = ScoreCount +10 where ID= '123456'";   $sql2 = "update ScoreDetail  set FScore = 300 where ID= '123456'";   $sql3 = "insert into  ScoreDetail ID,Score) values ('123456',60)";      $mysqli = new mysqli('localhost','root','','DB_Lib2Test');   $mysqli->autocommit(false);//开始事物   $mysqli->query($sql1);   $mysqli->query($sql2);   if(!$mysqli->errno){     $mysqli->commit();     echo 'ok';   }else{    echo 'err';     $mysqli->rollback();   }  

在这里,我们再使用 php mysql 系列函数执行事务。

view plain copy to clipboard print ?

$sql1 = "update User set ScoreCount = ScoreCount +10 where ID= '123456'";   $sql2 = "update ScoreDetail  set FScore = 300 where ID= '123456'";   $sql3 = "insert into  ScoreDetail ID,Score) values ('123456',60)";      $conn = mysql_connect('localhost','root','');   mysql_select_db('DB_Lib2Test');   mysql_query('start transaction');   //mysql_query('SET autocommit=0');      mysql_query($sql1);   mysql_query($sql2);   if(mysql_errno ()){       mysql_query('rollback');       echo 'err';   }else{       mysql_query('commit');       echo 'ok';   }      // mysql_query('SET autocommit=1');   //  mysql_query($sql3);  

在这里要注意,

MyISAM:不支持事务,用于只读程序提高性能 InnoDB:支持ACID事务、行级锁、并发 Berkeley DB:支持事务
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:PHP的Foreach다음 기사:{php 函数}