1. 程式人生 > >mysql一條語句update多條記錄

mysql一條語句update多條記錄

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

UPDATE mytable SET myfield='value' WHERE other_field='other_value';
 但是,如果你想更新多行資料,並且每行記錄的各欄位值都是各不一樣,你會怎麼辦呢?剛開始你可能會想到使用迴圈執行多條UPDATE語句的方式,就像以下的php程式示例:
foreach ($display_order as $id => $ordinal) {
    $sql="UPDATE categories SET display_order = $ordinal WHERE id = $id"
; mysql_query($sql); }
 這種方法並沒有什麼任何錯誤,並且程式碼簡單易懂,但是在迴圈語句中執行了不止一次SQL查詢,在做系統優化的時候,我們總是想盡可能的減少資料庫查詢的次數,以減少資源佔用,同時可以提高系統速度。幸運的是,還有更好的解決方案,只不過SQL語句稍微複雜點,但是隻需執行一次查詢即可,語法如下:
UPDATE mytable
    SET myfield = CASE other_field
        WHEN 1 THEN 'value'
        WHEN 2 THEN 'value'
        WHEN 3 THEN
'value' END WHERE id IN (1,2,3)
 這樣的SQL語句是很容易理解的,也就是用到了很多程式語言都有的關鍵字 CASE,根據id欄位值來進行不同分支的當型判斷,

 如果你需要更新一行記錄的多個欄位,可以用以下SQL語句:
UPDATE categories
    SET display_order = CASE id
        WHEN 1 THEN 3
        WHEN 2 THEN 4
        WHEN 3 THEN 5
    END,
    title = CASE id
        WHEN 1 THEN 'New Title 1'
WHEN 2 THEN 'New Title 2' WHEN 3 THEN 'New Title 3' END WHERE id IN (1,2,3)
 以上方案大大減少了資料庫的查詢操作次數,大大節約了系統資源,但是該怎樣與我們的程式語言結合起來呢?我們還是用剛才分類目錄的例子,以下是php的程式示例:



 在這個例子中總共更新了8行資料,但是隻執行了一次資料庫查詢,相比於迴圈執行8次UPDATE語句,以上例子所節約的時間可以說是微不足道的。但是想想,當你需要更新10,0000或者更多行記錄時,你會發現這其中的好處!唯一要注意的問題是SQL語句的長度,需要考慮程式執行環境所支援的字串長度,當然這也可以更新mysql的設定來擴充套件。