」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何根據同名其他行的資料更新表中的空值?

如何根據同名其他行的資料更新表中的空值?

發佈於2024-11-16
瀏覽:486

How do I update empty values in a table based on data from other rows with the same name?

在表中的行之間複製資料

在資料庫管理中,經常需要根據表中其他行的資料來更新行同一張桌子。考慮一個包含 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 |

這些方法提供了操作表中資料的彈性,可讓您根據包含同一表中其他行的條件更新值。

最新教學 更多>
  • 如何在 Go 中使用反射自訂 JSON 解組?
    如何在 Go 中使用反射自訂 JSON 解組?
    使用反射自訂 JSON 解組在 Go 中,將 JSON 解組為結構體是一個簡單的過程。然而,當處理具有自訂標籤的欄位時,例如 json:"some_field",標準的解組機制可能不夠。 處理這種情況的一種方法是使用反射。透過使用反射檢查結構體的字段,我們可以檢查字段是否具有特定...
    程式設計 發佈於2024-11-16
  • 如何輕鬆地將程式碼傳輸到 Python 解釋器中而不出現縮排問題?
    如何輕鬆地將程式碼傳輸到 Python 解釋器中而不出現縮排問題?
    便捷的代碼傳輸:繞過Python 的空白敏感度由於語言嚴格的空白,將代碼直接複製粘貼到Python 解釋器中可能會出現問題敏感度。這通常會導致意外的程式碼執行或語法錯誤。 IPython 作為解決方案IPython 是一種高級 Python 命令 shell,透過其專用命令。 %cpaste:將剪貼...
    程式設計 發佈於2024-11-16
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-16
  • Python 請求如何使用 Javascript 處理動態網站?
    Python 請求如何使用 Javascript 處理動態網站?
    克服 Python 請求的 Javascript 障礙傳統的 Python 請求旨在從靜態 HTML 頁面中提取資訊。然而,許多現代網站使用 Javascript 來動態獲取數據,這給 Requests 帶來了挑戰。 是否有解決方法可以利用 Javascript 頁面的 Requests ? 絕對可...
    程式設計 發佈於2024-11-16
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-16
  • 我們如何計算 JavaScript 物件的大致記憶體佔用量?
    我們如何計算 JavaScript 物件的大致記憶體佔用量?
    確定 JavaScript 物件的記憶體佔用在 JavaScript 中,了解物件的記憶體消耗對於優化效能和避免記憶體洩漏至關重要。本文解決了獲取 JavaScript 物件大小的查詢,深入研究了估計此類物件所佔用的大致記憶體的解決方案。 確定物件大小In JavaScript 中沒有專門設計的內建...
    程式設計 發佈於2024-11-16
  • 從本地主機到生產:OneBootcamp 的問題優先 SRE 之旅
    從本地主機到生產:OneBootcamp 的問題優先 SRE 之旅
    我在X(以前的Twitter)上遇到了One2N 舉辦的一個問題優先的SRE 訓練營(在這裡你可以構建一個應用程序,並將其從本地主機擴展到生產環境),我想,「哎呀是啊!我會嘗試一下。」這篇部落格文章開啟了我的旅程,我將記錄我在訓練營中處理每項練習的經驗。 這篇介紹文章將連結到其他條目,詳細介紹我對...
    程式設計 發佈於2024-11-16
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-16
  • 如何在Python中遞歸搜尋子資料夾並檢索檔案?
    如何在Python中遞歸搜尋子資料夾並檢索檔案?
    遞歸子資料夾搜尋與檔案擷取在程式設計領域,遍歷目錄和擷取檔案可能是一項常見任務。一種有效的方法是採用遞歸演算法搜尋子資料夾並累積滿足特定條件的檔案清單。 遇到的問題使用者遇到了障礙嘗試在遞歸子資料夾搜尋中建立特定檔案的清單時。該問題源於子資料夾變數拉入子資料夾清單而不是包含該檔案的目前資料夾。 子資...
    程式設計 發佈於2024-11-16
  • 如何使用 CSS 建立倒數計時器
    如何使用 CSS 建立倒數計時器
    Written by Carlos Mucuho✏️ Countdown timers are a popular feature on many websites, enhancing functionality for events, sales, and user engagement. Wh...
    程式設計 發佈於2024-11-16
  • ## 像素完美縮小可以在瀏覽器大小調整期間保存影像品質嗎?
    ## 像素完美縮小可以在瀏覽器大小調整期間保存影像品質嗎?
    透過縮小尺寸重新取樣會降低影像品質? 此處的目標是縮小影像的大小,同時在瀏覽器環境中保持其品質。使用 HTML5 畫布縮小影像時會出現此問題,導致影像品質下降。 縮小尺寸與插值縮小尺寸和插值是不同的技術。縮小是指透過組合來源影像中的像素以在目標影像中建立較少的像素來減小影像尺寸,而插值是指在放大時在...
    程式設計 發佈於2024-11-16
  • Python 3.x 的 super() 函數在沒有參數的情況下如何運作,有哪些潛在的陷阱以及如何避免它們?
    Python 3.x 的 super() 函數在沒有參數的情況下如何運作,有哪些潛在的陷阱以及如何避免它們?
    揭開Python 3.x神奇Super()的秘密Python 3.x引入了super()函數的一個特殊方面:可以在沒有參數的情況下呼叫它。這種看似平凡的行為隱藏了編譯時魔法和執行時間支援的強大組合,提供了巨大的靈活性和效率。 隱藏的編譯時魔法透過無參數的 super() 調用,Python 編譯器在...
    程式設計 發佈於2024-11-16
  • PHP如何將變數轉換為字串?
    PHP如何將變數轉換為字串?
    PHP中的字串轉換Java和.NET程式設計師可能習慣toString()方法,它提供了一種便捷的轉換方式任何物件到字串表示形式。 PHP 透過轉換運算子提供類似的功能。 PHP 的轉換運算子要將 PHP 變數轉換為字串,可以使用 (string) 轉換運算子。此語法允許您將任何類型的變數明確轉換為...
    程式設計 發佈於2024-11-16
  • 如何修復「無法將 MySQL 日期/時間值轉換為 System.DateTime」錯誤?
    如何修復「無法將 MySQL 日期/時間值轉換為 System.DateTime」錯誤?
    了解「無法將MySQL 日期/時間值轉換為System.DateTime」錯誤從MySQL 資料庫檢索資料有時會導致錯誤「無法將MySQL 日期/時間值轉換為System.DateTime」。當從資料庫檢索的資料的 DbType 與 .NET 資料類型的對應屬性不相容時,就會發生這種情況。 修正轉換...
    程式設計 發佈於2024-11-16
  • 如何使用 PDO 準備語句將多行插入資料庫?
    如何使用 PDO 準備語句將多行插入資料庫?
    使用PDO 準備好的語句插入多行使用單一準備好的語句將多行插入資料庫不僅是可能的,而且推薦用於使用單一插入查詢的方法第一種方法涉及使用具有多個值的單一INSERT 查詢:INSERT INTO Table (col1, col2, col3) VALUES ('abc', 'def', 'ghi'...
    程式設計 發佈於2024-11-16

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3