在PHP中 開始交易後,程式拋出異常 沒有執行commit也沒有執行rollback mysql事務會回溯嗎?
網路上有人說開啟事務後 sql語句執行錯誤或程式出錯 沒有執行rollback的情況下,下次執行就會自動commit
程式出錯不會回滾rollback
但是也有人說拋出異常等 程式如果MySQL存在沒有提交的事務,那麼這時候 AUTOCOMMIT 自動提交的參數應該是為 0 的。
不過如果你透過其他的語言的MySQL驅動來操作的話,這些驅動一般都帶有自動恢復 AUTOCOMMIT 的功能,在請求處理完成後會自動 ROLLBACK 沒有處理的事務。
回覆內容:
網路上有人說開啟事務後 sql語句執行錯誤或程式出錯 沒有執行rollback的情況下,下次執行就會自動commit
程式出錯不會回滾rollback
但是也有人說拋出異常等 程式如果MySQL存在沒有提交的事務,那麼這時候 AUTOCOMMIT 自動提交的參數應該是為 0 的。
不過如果你透過其他的語言的MySQL驅動來操作的話,這些驅動一般都帶有自動恢復 AUTOCOMMIT 的功能,在請求處理完成後會自動 ROLLBACK 沒有處理的事務。
這裡我預設你使用的是PDO吧。
官方文件是這樣說的:
PDO will automatically roll it backWhen the script ends or when a connection is about to be closed, if you have an outstanding transaction, PDO will automatically roll it back. This is a safety measure to help avoid helistd obectwlywere hell. you didn't explicitly commit the transaction, then it is assumed that something went awry, so the rollback is performed for the safety of your data.
意思是說,當腳本結束(包括正常結束或異常結束).
When the script ends or when a connection is about benection
文檔已經說的很清楚了。PDO會自動回滾。
如果你不是用的PDO驅動,可查看相關驅動文檔,或在問題中說清楚用的什麼驅動。
順便一提,之前的mysql_connect()函數官方已經不建議再使用了(was deprecated)。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MySQL和phpMyAdmin是強大的數據庫管理工具。 1)MySQL用於創建數據庫和表、執行DML和SQL查詢。 2)phpMyAdmin提供直觀界面進行數據庫管理、表結構管理、數據操作和用戶權限管理。

在MySQL中,外鍵的作用是建立表與表之間的關係,確保數據的一致性和完整性。外鍵通過引用完整性檢查和級聯操作維護數據的有效性,使用時需注意性能優化和避免常見錯誤。

IIS和PHP可以兼容,通過FastCGI實現。 1.IIS通過配置文件將.php文件請求轉發給FastCGI模塊。 2.FastCGI模塊啟動PHP進程處理請求,提高性能和穩定性。 3.實際應用中需注意配置細節、錯誤調試和性能優化。

MySQL和MariaDB的主要區別在於性能、功能和許可證:1.MySQL由Oracle開發,MariaDB是其分支。 2.MariaDB在高負載環境中性能可能更好。 3.MariaDB提供了更多的存儲引擎和功能。 4.MySQL採用雙重許可證,MariaDB完全開源。選擇時應考慮現有基礎設施、性能需求、功能需求和許可證成本。

SQL是一種用於管理關係數據庫的標準語言,而MySQL是一個使用SQL的數據庫管理系統。 SQL定義了與數據庫交互的方式,包括CRUD操作,而MySQL實現了SQL標準並提供了額外的功能,如存儲過程和触發器。

多次調用session_start()會導致警告信息和可能的數據覆蓋。 1)PHP會發出警告,提示session已啟動。 2)可能導致session數據意外覆蓋。 3)使用session_status()檢查session狀態,避免重複調用。

AI可以幫助優化Composer的使用,具體方法包括:1.依賴管理優化:AI分析依賴關係,建議最佳版本組合,減少衝突。 2.自動化代碼生成:AI生成符合最佳實踐的composer.json文件。 3.代碼質量提升:AI檢測潛在問題,提供優化建議,提高代碼質量。這些方法通過機器學習和自然語言處理技術實現,幫助開發者提高效率和代碼質量。

MySQL和phpMyAdmin可以通過以下步驟進行有效管理:1.創建和刪除數據庫:在phpMyAdmin中點擊幾下即可完成。 2.管理表:可以創建表、修改結構、添加索引。 3.數據操作:支持插入、更新、刪除數據和執行SQL查詢。 4.導入導出數據:支持SQL、CSV、XML等格式。 5.優化和監控:使用OPTIMIZETABLE命令優化表,並利用查詢分析器和監控工具解決性能問題。
