欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

SQL查詢中GROUP BY和DISTINCT有什么區別?

admin
2025年2月15日 8:19 本文熱度 472

引言

在SQL查詢中,GROUP BY和DISTINCT都是常用的關鍵字,它們都能實現數據去重的功能。但它們的實現原理和使用場景有很大的區別。

基本概念

DISTINCT

DISTINCT用于刪除結果集中的重復行,確保每個結果只出現一次。它作用于整個選擇的列組合。

GROUP BY

GROUP BY用于將具有相同值的行組合到匯總行中,通常與聚合函數(如COUNT、SUM、AVG等)一起使用。

實際案例分析

讓我們通過一個具體的案例來理解它們的區別。假設我們有一個訂單表(orders):

CREATE TABLE orders (
    order_id INT,
    customer_id INT,
    product_id INT,
    amount DECIMAL(10,2),
    order_date DATE
);

INSERT INTO orders VALUES
(11011100.00'2024-02-14'),
(21012200.00'2024-02-14'),
(31021150.00'2024-02-14'),
(41011300.00'2024-02-15');

使用DISTINCT的場景

如果我們想查看有哪些客戶下過訂單:

SELECT DISTINCT customer_id 
FROM orders;

-- 結果
customer_id
-----------
101
102

這個查詢會直接返回去重后的客戶ID列表。

使用GROUP BY的場景

如果我們想知道每個客戶的訂單總金額:

SELECT customer_id, 
       COUNT(*) as order_count,
       SUM(amount) as total_amount
FROM orders
GROUP BY customer_id;

-- 結果
customer_id  order_count  total_amount
-----------  -----------  ------------
101          3           600.00
102          1           150.00

GROUP BY不僅去除了重復,還能進行數據匯總計算。

主要區別

  1. 功能定位

    • DISTINCT:純粹的去重操作
    • GROUP BY:分組匯總,可以配合聚合函數使用
  2. 結果集

    • DISTINCT:直接返回去重后的數據
    • GROUP BY:返回分組匯總后的數據
  3. 性能表現

    • DISTINCT:對整個結果集進行去重,通常需要排序操作
    • GROUP BY:在分組的同時進行計算,可能涉及臨時表的創建
  4. 使用靈活性

    • DISTINCT:不能與聚合函數直接配合使用(除特殊情況外)
    • GROUP BY:可以配合多種聚合函數,支持復雜的分組計算

總結

  1. DISTINCT和GROUP BY雖然都能實現去重,但它們的使用場景和功能特點有明顯區別。

  2. DISTINCT適合簡單的去重場景,而GROUP BY更適合需要分組統計的場景。

  3. 在選擇使用哪種方式時,需要考慮:

    • 業務需求是否需要分組統計
    • 性能要求
    • 結果集的預期大小
    • 是否需要使用聚合函數
  4. 合理使用索引和優化查詢語句,可以顯著提升查詢性能。


閱讀原文:原文鏈接


該文章在 2025/2/17 12:25:44 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved