码迷,mamicode.com
首页 > 数据库 > 详细

sqlserver中分区函数 partition by与 group by 区别 删除关键字段重复列

时间:2018-01-19 14:04:46      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:bsp   字段   nbsp   post   sele   并且   rank   部分   over   

partition  by关键字是分析性函数的一部分,它和聚合函数(如group by)不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录,

partition  by用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组。

partition by 与group by不同之处在于前者返回的是分组里的每一条数据,并且可以对分组数据进行排序操作。后者只能返回聚合之后的组的数据统计值的记录。

 

用法 : select *,ROW_NUMBER() over( partition by Name order by Score )  as newrow
from table

删除关键字段重复列

@newtable  ---表名 

@key  --自增列

@repeate  ---查重复的关键字段

delete ‘ +@newtable+‘ where ‘ +@key+‘ in(select ‘ +@key+‘ from (select *,RANK() over(partition by ‘+@repeate+‘  order by ‘+@key+‘ ) as newrow from ‘+@newtable+‘) nt where nt.newrow>1)

sqlserver中分区函数 partition by与 group by 区别 删除关键字段重复列

标签:bsp   字段   nbsp   post   sele   并且   rank   部分   over   

原文地址:https://www.cnblogs.com/cuozhixu/p/8316250.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!