php中對MYSQL操作之事務控制,復原

來源:互聯網
上載者:User

標籤:資料庫   php   事務   mysqli   

<?php//事務控制,復原//建立一個mysqli對象$mysqli = new MySQLi("主機名稱","mysql使用者名稱","密碼","資料庫名");//判斷是否連結成功if($mysqli->connect_error){die($mysqli->connect_error);}//由於在事務提交中系統預設提交,故這裡設定為FALSE先不提交$mysqli->autocommit(false);//其實這裡系統已經相當在這裡做個儲存點,記錄此時所有狀態,復原是復原到這裡//$mysqli->savepoint a;//寫出對資料庫的動作陳述式$sql1 = "insert into 表名 (欄位名) values (對應欄位的值)";$sql2 = "update 表名 set 欄位名=值 where 條件";$sql3 = "delete from 表名 where 條件";//執行sql語句$res1 = $mysqli->query($sql1) or die ($mysqli->error);$res2 = $mysqli->query($sql2) or die ($mysqli->error);$res3 = $mysqli->query($sql3) or die ($mysqli->error);//判斷是否都執行成功if(!$res1||!$res2||!$res3){//只要有一條失敗便復原,都不執行,若設定滾回點,如a,加個參數a變滾回到a處$mysqli->rollback();}else{//一旦提交無法復原,成功則提交$mysqli->commit();}//關閉資源$musqli->close();?>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.