在表中的行之間複製資料
在資料庫管理中,經常需要根據表中其他行的資料來更新行同一張桌子。考慮一個包含 ID、NAME 和 VALUE 欄位的表,其中包含重複的 NAME 值,如下所示:
ID | NAME | VALUE | ---------------------------- 1 | Test | VALUE1 | 2 | Test2 | VALUE2 | 1 | Test2 | | 4 | Test | | 1 | Test3 | VALUE3 |
假設我們要更新具有重複 NAME 值的行中的空 VALUE 欄位。為了實現這一點,我們可以使用引用和更新同一個表中的值的 SQL 查詢。
一種方法涉及使用具有聯結的 UPDATE 語句。在以下查詢中,我們連接 data_table 兩次,將它們別名為 dt1 和 dt2:
UPDATE data_table dt1, data_table dt2 SET dt1.VALUE = dt2.VALUE WHERE dt1.NAME = dt2.NAME AND dt1.VALUE = '' AND dt2.VALUE != ''
此查詢標識空VALUE 欄位(其中dt1.VALUE 為空)並將其更新為非空來自具有相同NAME 的其他行的VALUE(其中dt2.VALUE 不為空)。
作為替代方案,我們可以使用子查詢來識別具有非空VALUE 的行並將其連接回原始表用於更新:
UPDATE data_table t, (SELECT DISTINCT ID, NAME, VALUE FROM data_table WHERE VALUE IS NOT NULL AND VALUE != '') t1 SET t.VALUE = t1.VALUE WHERE t.ID = t1.ID AND t.NAME = t1.NAME
這兩個查詢都會產生所需的輸出:
ID | NAME | VALUE | ---------------------------- 1 | Test | VALUE1 | 2 | Test2 | VALUE2 | 1 | Test2 | VALUE2 | 4 | Test | VALUE1 | 1 | Test3 | VALUE3 |
這些方法提供了操作表中資料的彈性,可讓您根據包含同一表中其他行的條件更新值。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3