PHP 中mysql如何?事務提交?

來源:互聯網
上載者:User

標籤:

事務就是指對資料庫的多次修改,要麼全部成功,要麼全部失敗,不能出現部分修改成功,部分修改失敗的情況。

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如何?事務提交?

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.