美图齐众专注资阳网站设计 资阳网站制作 资阳网站建设
资阳网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

SQL中的分析函数

本文将为您介绍SQL中的分析函数,除了ORDER BY(按…排序)语句外,分析函数是一条查询被执行的操作,供您参考,希望对您学习SQL函数的使用能够有所帮助。

创新互联于2013年成立,先为波密等服务建站,波密等地企业,进行企业商务咨询服务。为波密企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

所有合并、WHERE、GROUP BY、HAVING语句都是分析函数处理之前完成的。

因此,分析函数只出现在选择目录或ORDER BY(按…排序)语句中。 

使用Over语句的情况 :

A. 等级函数如, ROW_NUMBER, DENSE_RANK, RANK, NTILE 使用 OVER(ORDER BY) 语句

example.

 
 
 
  1. view sourceprint?01 USE AdventureWorks;    
  2.  
  3. 02 GO    
  4.  
  5. 03 SELECT c.FirstName, c.LastName    
  6.  
  7. 04     ,ROW_NUMBER() OVER(ORDER BY SalesYTD DESC) AS 'Row Number'   
  8.  
  9. 05     ,s.SalesYTD, a.PostalCode    
  10.  
  11. 06 FROM Sales.SalesPerson s     
  12.  
  13. 07     INNER JOIN Person.Contact c     
  14.  
  15. 08         ON s.SalesPersonID = c.ContactID    
  16.  
  17. 09     INNER JOIN Person.Address a     
  18.  
  19. 10         ON a.AddressID = c.ContactID    
  20.  
  21. 11 WHERE TerritoryID IS NOT NULL    
  22.  
  23. 12     AND SalesYTD <> 0;    
  24.  
  25. 13 GO   
  26.  
  27.    

ROW_NUMBER() 增添顺序序号,即时存在相同的也递增序号

RANK()相同的数据序号相同,接下来为跳号(是跳跃排序,有两个第二名时接下来就是第四名)

dense_rank()相同的数据序号相同,接下来顺序递增序号(是连续排序,有两个第二名时仍然跟着第三名)

ntile(N)将记录分为N组。

B. 聚合函数如,  SUM,AVG,COUNT,MIN,MAX等使用OVER(PARTITION BY)语句

Example.

 
 
 
  1. 01 Copy Code     
  2.  
  3. 02 USE AdventureWorks;    
  4.  
  5. 03 GO    
  6.  
  7. 04 SELECT SalesOrderID, ProductID, OrderQty    
  8.  
  9. 05     ,SUM(OrderQty) OVER(PARTITION BY SalesOrderID) AS 'Total'   
  10.  
  11. 06     ,AVG(OrderQty) OVER(PARTITION BY SalesOrderID) AS 'Avg'   
  12.  
  13. 07     ,COUNT(OrderQty) OVER(PARTITION BY SalesOrderID) AS 'Count'   
  14.  
  15. 08     ,MIN(OrderQty) OVER(PARTITION BY SalesOrderID) AS 'Min'   
  16.  
  17. 09     ,MAX(OrderQty) OVER(PARTITION BY SalesOrderID) AS 'Max'   
  18.  
  19. 10 FROM Sales.SalesOrderDetail     
  20.  
  21. 11 WHERE SalesOrderID IN(43659,43664);    
  22.  
  23. 12 GO    
  24.  
  25.    

【编辑推荐】

创建SQL函数的实例

SQL中一个很好用的日期格式化函数

SQL中返回计算表达式的函数

SQL中DATENAME函数的用法

SQL中循环语句的效果实例


新闻名称:SQL中的分析函数
文章起源:http://zsjierui.cn/article/cojjcdo.html

其他资讯