0007《SQL必知必會》筆記03-彙總與分組數據

来源:http://www.cnblogs.com/sonng/archive/2016/04/13/5384713.html
-Advertisement-
Play Games

1、有些時候需要數據的彙總值,而不是數據本身,比如對某些數據求和、計數、求最大最小值、求平均值,因此就有了5個聚集函數:AVE()、COUNT()、MAX()、MIN()、SUM(): (1)求平均值:AVE(),一個AVG()只對一個欄位有效,註意AVE()忽略NULL值,而不是將其作為“0”參與 ...


1、有些時候需要數據的彙總值,而不是數據本身,比如對某些數據求和、計數、求最大最小值、求平均值,因此就有了5個聚集函數:AVE()、COUNT()、MAX()、MIN()、SUM():

  (1)求平均值:AVE(),一個AVG()只對一個欄位有效,註意AVE()忽略NULL值,而不是將其作為“0”參與計算

SELECT AVG(欄位名1),```,AVG(欄位名n) FROM 表名 WHERE 字句;

    

  (2)計數:COUNT(),兩種用法:COUNT(*):對錶中行數進行計數,不管是否有NULL;COUNT(欄位名):對特定列有數據的行進行計數,忽略NULL值

  (3)求最大、最小值:MAX()、MIN():多用於數值和日期,文本也可以用,升序排列的最大或最小值。都忽略NULL

  (4)求和:SUM():可以對單個列求和,也可以對多個列乘積求和:

  (5)ALL與DISTINCT:可用於以上5個函數,預設是ALL,對非重覆值計算是DISTINCT,用在函數的參數中,與欄位名用空格隔開

  (6)聚集函數的組合:以上幾個函數可以包含在SELECT語句中,比如求Products中的商品總數、平均價格、最高價格、最低價格

2、將數據在邏輯上進行分組:比如求各個供應商的商品總數、平均價格、最高價格、最低價格

  

  (1)GROUP BY的使用規定:

    1.GROUP BY 語句必須出現在WHERE之後,ORDER BY 之前

    2.分組列中若有NULL,這也將作為一組

    3.除聚集計算語句外,SELECT中的選擇列必須出現在GROUP BY 中

    4.GROUP BY 的列必須是檢索列或者表達式,若是在SELECT中使用的表達式,在GROUP BY 中也要使用相同的表達式,還不能用別名

    5.GROUP BY 可以包含任意數目的列,可以嵌套

3、將分組進行過濾:HAVING,與GROUP BY 配合使用,與WHERE類似,只是WHERE針對行,HAVING針對邏輯分組,比如列出有2個及以上產品,並且其價格大於等於4的供應商:

    WHERE過濾掉的行不參與GROUP BY的分組

4、分組(GROUP BY)與排序(ORDER BY):GROUP BY輸出的數據不一定有順序;ORDER BY 可以使用任意列(包括非選擇列),但GROUP BY只能且必須使用選擇列火表達式列;ORDER BY 可以沒有,但GROUP BY 在有選擇列(或表達式列)與聚集函數一起時,必須使用。

5、SELECT、FROM、WHERE、GROUP BY、HAVIN、GORDER BY順序

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 利用Intent實現有返回結果的頁面跳轉 主要用的方法: (1)Intent的構造方法:intent(當前界面對象,要跳轉的界面.class); (2)接受結果的方法onActivityResult(int requestCode, int resultCode, Intent data) (3)調 ...
  • 恢復內容開始 //需要的效果 1.設置window的根視圖控制器為一個UITableViewController #import "AppDelegate.h"#import "YCTableViewController.h"@interface AppDelegate ()@end@impleme ...
  • 當使用閉包時,類本身持有self,然後又在閉包中訪問了self或者self的屬性,就會導致噁心額迴圈引用。swift提供的解決方法是在閉包中定義捕獲列表,捕獲列表是閉包想怎麼引用捕獲來的變數。例如下麵定義了一個捕獲列表,引用self為unowned引用,這樣在賓傲中用self就不會導致迴圈引用 去掉 ...
  • 一,效果圖。 二,工程圖。 三,代碼。 RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController : UIViewController <UITextViewDelegate> @end RootViewCo ...
  • 如圖 添加如下代碼 sTableView.separatorInset = UIEdgeInsetsZero; sTableView.layoutMargins = UIEdgeInsetsZero; cell.layoutMargins = UIEdgeInsetsZero; 第二種方法如下圖 - ...
  • 為了實現在ios系統上抓包,如下步驟: 1,設備越獄 2,在cydia-軟體源-設置中改為開發者,否則有些deb搜索不到 安裝如下軟體:OpenSSH,OpenSSL,wget (下載工具) Aptitude 及 APT 0.6 Transitional (deb包工具) unzip 及 zip ( ...
  • MYSQL啟動報1067錯誤,系統日誌中是“服務 mysql 意外停止” Mysql日誌中則是:“Plugin 'FEDERATED' is disabled” 網我在網上找到解決方案:1、在MY.INI文件中的 [mysqld] 中增加一行tmpdir="D:/MySQL/data/"修改後,還是 ...
  • 一同事跟我反饋他遇到了一個SQL性能問題,他說全表只有69條記錄,客戶端執行耗費了兩分多鐘,這不科學呀。要我分析一下原因並解決。我按照類似表結構,構造了一個案例,測試截圖如下所示 這個表有13800KB(也就是13M多大小),因為該表將圖片保存到資料庫(Item_Photo欄位為iamge類型),這... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...