mysql安裝及配置超詳細教程「mysql刷新命令」

通常情況下,我們會使用以下SQL語句來更新欄位值:

UPDATE mytable SET myfield='value' WHERE other_field='other_value';

但是,如果你想更新多行數據,並且每行記錄的各欄位值都是各不一樣,你會怎麼辦呢?剛開始你可能會想到使用循環執行多條UPDATE語句的方式,就像以下的python程序示例:

for x in xrange(10):
 sql = ''' UPDATE mytable SET myfield='value' WHERE other_field='other_value'; '''

這種方法並沒有什麼任何錯誤,並且代碼簡單易懂,但是在循環語句中執行了不止一次SQL查詢,在做系統優化的時候,我們總是想儘可能的減少資料庫查詢的次數,以減少資源佔用,同時可以提高系統速度。幸運的是,還有更好的解決方案,只不過SQL語句稍微複雜點,但是只需執行一次查詢即可,語法如下:

詳解Mysql Update批量更新的幾種方式

這樣的SQL語句是很容易理解的,也就是用到了很多編程語言都有的關鍵字 CASE,根據id欄位值來進行不同分支的當型判斷,

如果你需要更新一行記錄的多個欄位,可以用以下SQL語句:

詳解Mysql Update批量更新的幾種方式

以上方案大大減少了資料庫的查詢操作次數,大大節約了系統資源

不過這個有個缺點 : 要注意的問題是SQL語句的長度,需要考慮程序運行環境所支持的字元串長度,當然這也可以更新mysql的設置來擴展。

當然python這麼強大的語言還給我們提供了executemany 這麼強大的方法 ,它不僅可以插入數據 當然也可以用於更新數據 作為一個經常搞事情的人 這些東西要經常相互用下 才可以對比出結果

詳解Mysql Update批量更新的幾種方式

是不是這個更方便一些 但是嗎 速度 問題 我感覺可以和第二種結合一下對比一下會更好呢

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/268125.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-16 13:07
下一篇 2024-12-16 13:07

相關推薦

發表回復

登錄後才能評論