標籤:
事務就是指對資料庫的多次修改,要麼全部成功,要麼全部失敗,不能出現部分修改成功,部分修改失敗的情況。
PHP下操作mysql資料庫要實現事務提交,需注意以下方面:
1, 資料庫表格儲存體引擎類型設定為innoDB。預設的mysql表採用MYISAM引擎,是不支援事務的,因此要採用以下語句變更:
mysql> alter table ‘table_name’ engine=innodb;
2,PDO對象設定要設定errmode為Exception,否則第16行SQL執行出錯,語句也不會跳到catch段去rollback, 而是繼續向下執行直到commit。
1 try { 2 $pdo = new PDO($dsn, $user, $pass); //初始化一個PDO對象,就是建立了資料庫連接對象$pdo 3 $pdo->setAttribute (PDO::ATTR_ERRMODE , PDO::ERRMODE_EXCEPTION ); 4 $pdo->beginTransaction(); //開啟事務 5 $query="正確的語句"; 6 $result=$pdo->prepare($query); 7 8 if($result->execute()){ 9 echo "資料添加成功!";10 }else{11 echo "資料添加失敗!";12 }13 14 15 $query="錯誤的語句";16 $result=$pdo->prepare($query);17 18 if($result->execute()){19 echo "資料添加成功!";20 }else{21 echo "資料添加失敗!";22 } 23 24 25 $pdo->commit(); //執行事務的提交操作26 } catch (PDOException $e) {27 die ("Error!: " . $e->getMessage() . "<br/>");28 $pdo->rollBack(); //執行事務的復原29 }
PHP 中mysql如何?事務提交?