首頁 > 資料庫 > mysql教程 > SQL 聚合函數如何將具有 NULL 值的多行合併為一行?

SQL 聚合函數如何將具有 NULL 值的多行合併為一行?

Barbara Streisand
發布: 2024-12-28 06:12:14
原創
529 人瀏覽過

How Can SQL Aggregate Functions Merge Multiple Rows with NULL Values into a Single Row?

在SQL 中選擇資料來合併多行

考慮一個包含資料的表,如下所示:

FK Field1 Field2
3 ABC NULL
3 NULL DEF

目標是執行將這些行合併為一行的SELECT操作:

FK Field1 Field2
3 ABC DEF

聚合函數解決方案

可以使用聚合函數來忽略 NULL 值並組合多個匹配行中的非 NULL 值。下面的查詢示範了這種方法:

SELECT
    FK,
    MAX(Field1) AS Field1,
    MAX(Field2) AS Field2
FROM
    table1
GROUP BY
    FK;
登入後複製

在此查詢中,我們使用 MAX 聚合函數從按 FK 分組的行中選擇 Field1 和 Field2 的最大值。由於聚合函數會忽略 NULL 值,因此這可確保僅組合非 NULL 值。

測試解決方案

使用提供的測試資料:

CREATE TABLE table1 (FK int, Field1 varchar(10), Field2 varchar(10));

INSERT INTO table1 VALUES (3, 'ABC', NULL);
INSERT INTO table1 VALUES (3, NULL, 'DEF');
INSERT INTO table1 VALUES (4, 'GHI', NULL);
INSERT INTO table1 VALUES (4, 'JKL', 'MNO');
INSERT INTO table1 VALUES (4, NULL, 'PQR');
登入後複製

查詢產生所需的結果:

FK Field1 Field2
3 ABC DEF
4 JKL PQR

以上是SQL 聚合函數如何將具有 NULL 值的多行合併為一行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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