Sql Server 開窗函數Over()的使用

来源:https://www.cnblogs.com/SmileIven/archive/2018/05/30/9109528.html
-Advertisement-
Play Games

利用over(),將統計信息計算出來,然後直接篩選結果集 1 declare @t table( 2 ProductID int, 3 ProductName varchar(20), 4 ProductType varchar(20), 5 Price int) 6 7 insert @t 8 s ...


利用over(),將統計信息計算出來,然後直接篩選結果集
 1 declare @t table(
 2 ProductID int,
 3 ProductName varchar(20),
 4 ProductType varchar(20),
 5 Price int)
 6  
 7 insert @t
 8 select 1,'name1','P1',3 union all
 9 select 2,'name2','P1',5 union all
10 select 3,'name3','P2',4 union all
11 select 4,'name4','P2',4

 

查詢要求:查出每類產品中價格最高的信息
--做法一:找到每個組裡,價格最大的值;然後再找出每個組裡價格等於這個值的
--缺點:要進行一次join
    
select t1.* from @t t1
  join (select ProductType, max(Price) Price from @t group by ProductType) t2 
  on t1.ProductType = t2.ProductType
 where t1.Price = t2.Price
 order by ProductType

 



--做法二:利用over(),將統計信息計算出來,然後直接篩選結果集。
--over() 可以讓函數(包括聚合函數)與行一起輸出。
 
;with cte as(select *, max(Price) over(partition by (ProductType)) MaxPrice from @t)
select ProductID,ProductName,ProductType,Price from cte where Price = MaxPrice
 order by ProductType

 



-over() 的語法為:over([patition by ] <order by >)。需要註意的是,over() 前面是一個函數,如果是聚合函數,那麼order by 不能一起使用。
--over() 的另一常用情景是與 row_number() 一起用於分頁。

現在來介紹一下開窗函數。

視窗函數OVER()指定一組行,開窗函數計算從視窗函數輸出的結果集中各行的值。 

開窗函數不需要使用GROUP BY就可以對數據進行分組,還可以同時返回基礎行的列和聚合列。  

1.排名開窗函數

ROW_NUMBER、DENSE_RANK、RANK、NTILE屬於排名函數。

排名開窗函數可以單獨使用ORDER BY 語句,也可以和PARTITION BY同時使用。

PARTITION BY用於將結果集進行分組,開窗函數應用於每一組。

ODER BY 指定排名開窗函數的順序。在排名開窗函數中必須使用ORDER BY語句。

例如查詢每個雇員的定單,並按時間排序

;WITH OrderInfo AS
(
 SELECT ROW_NUMBER() OVER(PARTITION BY EmployeeID ORDER BY OrderDate) AS Number,
 OrderID,CustomerID, EmployeeID,OrderDate FROM Orders (NOLOCK) 
)
SELECT Number,OrderID,CustomerID, EmployeeID ,OrderDate
From OrderInfo WHERE Number BETWEEN 0 AND 10

 



視窗函數根據PARTITION BY語句按雇員ID對數據行分組,然後按照ORDER BY 語句排序,排名函數ROW_NUMBER()為每一組的數據分從1開始生成一個序號。 

ROW_NUMBER()為每一組的行按順序生成一個唯一的序號

RANK()也為每一組的行生成一個序號,與ROW_NUMBER()不同的是如果按照ORDER BY的排序,如果有相同的值會生成相同的序號,並且接下來的序號是不連序的。例如兩個相同的行生成序號3,那麼接下來會生成序號5。

DENSE_RANK()和RANK()類似,不同的是如果有相同的序號,那麼接下來的序號不會間斷。也就是說如果兩個相同的行生成序號3,那麼接下來生成的序號還是4。

NTILE (integer_expression) 按照指定的數目將數據進行分組,併為每一組生成一個序號。

2.聚合開窗函數

很多聚合函數都可以用作視窗函數的運算,如SUM,AVG,MAX,MIN。

聚合開窗函數只能使用PARTITION BY子句或都不帶任何語句,ORDER BY不能與聚合開窗函數一同使用。

例如,查詢雇員的定單總數及定單信息
WITH OrderInfo AS
(
SELECT COUNT(OrderID) OVER(PARTITION BY EmployeeID) AS TotalCount,OrderID,CustomerID, EmployeeID,OrderDate FROM Orders (NOLOCK)
)
SELECT OrderID,CustomerID, EmployeeID ,OrderDate,TotalCount From OrderInfo ORDER BY EmployeeID 

 

如果視窗函數不使用PARTITION BY 語句的話,那麼就是不對數據進行分組,聚合函數計算所有的行的值
WITH OrderInfo AS
 (
  SELECT COUNT(OrderID) OVER() AS Count,OrderID,CustomerID, EmployeeID,OrderDate FROM Orders (NOLOCK)
 )

 


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

-Advertisement-
Play Games
更多相關文章
  • zkServer.sh start //啟動zk進程 zkServer.sh stop //關閉zk進程 zkServer.sh status //查看zk狀態 zkCli.sh //啟動本地zk客戶端 zkCli.sh -server localhost:2181 //啟動遠程zk客戶端 ====... ...
  • MySQL資料庫對大小寫不敏感,如id和ID,select和SELECT.。 1.資料庫 create database <資料庫名> 創建資料庫 use <資料庫名> 連接資料庫 註:use表示當前連接上了哪個資料庫,並不會影響對其他資料庫的訪問 如: use db_1; select * fro ...
  • 自增主鍵沒有持久化是個比較早的bug,這點從其在官方bug網站的id號也可看出(https://bugs.mysql.com/bug.php?id=199)。由Peter Zaitsev(現Percona CEO)於2003年提出。歷史悠久且臭名昭著。 首先,直觀的重現下。 雖然id為3的記錄刪除了 ...
  • 在MySQL的日常維護中,我們總會遇到這樣或那樣的問題,對於那些經常發生且有處理經驗的事故,不論是新手還是老司機都能在故障規定的容錯時間內解決。而對於那些不常見、比較棘手的問題,新手上路可能就顯得舉足無措了,這個時候新手和老司機的差距就體現出來了。從知識儲備還是工作經驗,可能老司機比新手強一點,但如 ...
  • CentOS 下 MySQL 5.6 基於 RPM 的下載、安裝、配置 系統: CentOS 7 x86_64 MySQL 版本: 5.6.40 安裝方式: RPM 下載 "下載地址" 操作系統 選擇 Red Hat Enterprise Linux / Oracle Linux 系統版本 選擇 R ...
  • 首先創建 聚集函數: 接著上一個 樣例: 在訂單明細表按 和`season ticket_code order_id`去除重覆並且拼接起來 最後查詢結果截圖: ...
  • 1、redis兩種存儲機制(持久化) Redis的存儲機制分為:Snapshot和AOF 都先將記憶體存儲在記憶體中。 (1)Snapshot當數據累計到一定的閾值,就會觸發dump將數據一次性寫入到數據文件RDB文件。批量數據存儲,寫入頻率低,效率也高。但是安全性小,redis宕機,沒有寫入的數據會造 ...
  • -- 登錄資料庫 mysql -uroot -pmysql; -- 不顯示密碼 mysql -uroot -p -- 退出資料庫quit/exit/ctrl + d -- sql語句最後需要有分號;結尾 -- 顯示資料庫版本 version select version(); -- 顯示時間 now ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...