最新活动:电脑PC端+手机端+微网站+自适应网页多模板选择-建站388元起价!!!
当前位置:主页 > 网站建设 > SQL Server 总结复习 (二)建站知识

SQL Server 总结复习 (二)建站知识

时间:2023-05-23 22:05:23 阅读: 文章分类: 网站建设 作者: 网络小编

导读:1建站知识SQL Server 总结复习,学习sqlserver的朋友可以参考下网站建设制作百度seo网站优化。

网站建设制作百度seo网站优化1. 排名函数与PARTITION BY

复制代码 代码如下:

--所有数据 SELECT * FROM dbo.student AS a INNER JOIN dbo.ScoreTB AS b ON a.Id = b.stuid WHERE scorename = '语文' ------------------------------------------- --ROW_NUMBER() 的使用 生成列从1开始依次增加 ------------------------------------------- SELECT ROW_NUMBER() OVER (ORDER BY B.SCORE DESC) AS ROWNUMBER ,A.NAME, B.SCORE, a.Id FROM dbo.student AS a INNER JOIN dbo.ScoreTB AS b ON a.Id = b.stuid WHERE scorename = '语文' --也可以在后面再加一个order by,则表示前面生成后的全部列又被以最后的列重新排列(排名列值不变) SELECT ROW_NUMBER() OVER (ORDER BY B.SCORE DESC) AS ROWNUMBER ,A.NAME, B.SCORE, a.Id FROM dbo.student AS a INNER JOIN dbo.ScoreTB AS b ON a.Id = b.stuid WHERE scorename = '语文' ORDER BY a.Id --要在分组统计后使用排名函数,则先进行分组,用cte或嵌套查询表整出结果集,再用row_number函数处理 WITH b AS ( SELECT stuid, SUM(score) AS score FROM ScoreTB GROUP BY stuid ) SELECT * ,ROW_NUMBER() OVER (ORDER BY b.score desc) AS rownumer FROM dbo.student AS a INNER JOIN b ON a.id = b.stuid ---------------------------------------------------------------------------- --RANK() 用法与ROW_NUMER函数想同,只是在出现order by同级时,排名会设置成一样,而下一个会根据之前的记录数生成序号 --例如前面三个是一样的,那么都是1,下一个则是4,示例略 ---------------------------------------------------------------------------- ---------------------------------------------------------------------------- --DENSE_RANK() 密集排名 用法与ROW_NUMER、RANK函数相同,只是在生成序号时是连续的,而rank函数生成的序号有可能不连续 --例如前面三个是一样的,那么都是1,下一个则是2,示例略 ---------------------------------------------------------------------------- ---------------------------------------------------------------------------- --ntile函数可以对序号进行分组处理。这就相当于将查询出来的记录集放到指定长度的数组中,每一个数组元素存放一定数量的记录。 --为每条记录生成的序号就是这条记录所有的数组元素的索引(从1开始)。也可以将每一个分配记录的数组元素称为“桶”。 --它有一个参数,用来指定桶数,例如 ---------------------------------------------------------------------------- SELECT ntile(2) OVER (ORDER BY B.SCORE DESC) AS GROUPID ,A.NAME, ISNULL(B.SCORE,0) SCORE, a.Id FROM dbo.student AS a LEFT JOIN dbo.ScoreTB AS b ON a.Id = b.stuid AND scorename = '语文' -------------------------------------------------------------------------- --PARTITION BY 类似于向排名函数应用一个group by,分组后对每一个组单独排名 -------------------------------------------------------------------------- --统计各个学科的排名依次为: SELECT RANK() OVER (PARTITION BY b.scorename ORDER BY B.SCORE DESC) AS ROWNUMBER,b.scorename, b.score, A.NAME, a.Id FROM dbo.student AS a INNER JOIN dbo.ScoreTB AS b ON a.Id = b.stuid ORDER BY SCORENAME

关键词标签: 标题 标签 SQL

声明: 本文由我的SEOUC技术文章主页发布于:2023-05-23 ,文章SQL Server 总结复习 (二)建站知识主要讲述标签,标题,SQL网站建设源码以及服务器配置搭建相关技术文章。转载请保留链接: https://www.seouc.com/article/web_6108.html

我的IDC 网站建设技术SEOUC.COM
专注网站建设,SEO优化,小程序设计制作搭建开发定制网站等,数千家网站定制开发案例,网站推广技术服务。
  • 5000+合作客服
  • 8年从业经验
  • 150+覆盖行业
  • 最新热门源码技术文章