首頁 > 資料庫 > mysql教程 > 為什麼 Python 中重複的 MySQL 查詢會回傳相同的結果?

為什麼 Python 中重複的 MySQL 查詢會回傳相同的結果?

Patricia Arquette
發布: 2024-11-08 21:10:02
原創
260 人瀏覽過

Why Do Repeated MySQL Queries in Python Return Identical Results?

Python 中重複 MySQL 查詢的持久資料擷取

在 Python 腳本編寫中,頻繁查詢 MySQL 資料庫以擷取動態資料至關重要。當依靠循環來檢索此類數據時,發現後續提取返回相同的結果可能會令人困惑。

問題

在給定的Python 腳本中,循環用於重複執行MySQL查詢並將結果儲存在清單中:

儘管預期循環會在每次迭代時刷新從資料庫檢索的數據,但腳本

解決方案

問題的癥結在於MySQL的事務隔離級別。預設情況下,MySQL 使用的儲存引擎InnoDB 在READ COMMITTED 隔離等級下運行,這可確保以下內容:

「相同交易內的一致性讀取會讀取第一次讀取建立的快照。為了解決這個問題,迴圈的每次迭代都必須以 mydb.commit() 指令結束。

透過提交連接,腳本強制資料庫擷取交易期間所做的更改,確保後續查詢反映了資料庫的當前狀態。

說明

MySQL 連線中的每個循環迭代都被視為一個單獨的事務,預設讀取來自一致的快照。在每次迭代結束時提交連線可確保後續事務讀取最新的快照,反映前一個事務中所做的變更。

以上是為什麼 Python 中重複的 MySQL 查詢會回傳相同的結果?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板