Rumah > pembangunan bahagian belakang > tutorial php > PHP Mysql Transaction

PHP Mysql Transaction

WBOY
Lepaskan: 2016-06-23 14:36:16
asal
915 orang telah melayarinya

在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:支持事务
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan