SQL SERVER 查询去重 PARTITION BY

rownumber() over(partition by col1 order by col2)去重的方法,很不错,在此记录下:

row_number() OVER ( PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的).

直接查询,中间很多相同的,但我只想取createdate时间最大的一条

select  fromid,subunstall,kouchu,creatdate,syncdate,relate_key from BoxCount_Froms_Open 

 

使用 PARTITION BY fromid ORDER BY creatdate DESC   根据中的 fromid分组,根据creatdate组内排序

WHERE RN= 1;取第一条数据

SELECT * FROM (SELECT fromid,subunstall,kouchu,creatdate,syncdate,relate_key,ROW_NUMBER() OVER( PARTITION BY fromid ORDER BY creatdate DESC)RN FROM BoxCount_Froms_Open ) T  WHERE RN= 1;

 

转载于:https://www.cnblogs.com/AlexLeeLi/p/7248482.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 SQL Server 中,您可以使用 `DISTINCT` 关键字来去除多行重复数据。例如,以下语句将会选择表中 `name` 和 `age` 两列,并去除重复数据: ``` SELECT DISTINCT name, age FROM table_name; ``` 如果您想要去除表中的重复记录,可以使用以下语句: ``` WITH cte AS ( SELECT *, ROW_NUMBER() OVER (PARTITION BY column_name ORDER BY column_name) AS rn FROM table_name ) DELETE FROM cte WHERE rn > 1; ``` 其中,`table_name` 是您要去除重复记录的表名,`column_name` 是您要去重的列名。这个语句将会保留每组重复记录中的第一条记录,并删除其余所有记录。 另外,如果您只想要去除指定列中的重复数据,可以使用以下语句: ``` SELECT DISTINCT column_name, other_column_name FROM table_name; ``` 其中,`column_name` 是您要去重的列名,`other_column_name` 是您要选择的其他列名。这个语句将会去除 `column_name` 列中的重复数据,并选择指定的其他列。 ### 回答2: 在SQL Server中实现多行去重的常用方法有以下几种: 1. 使用DISTINCT关键字:DISTINCT关键字用于从结果集中去除重复的行。例如,如果有一张名为table1的表,其中有多列包含重复的数据,可以使用SELECT DISTINCT语句按列名来去重。示例代码如下: ```sql SELECT DISTINCT column1, column2, column3 FROM table1 ``` 2. 使用GROUP BY和HAVING子句:GROUP BY子句可以将结果集按照指定的列进行分组,而HAVING子句用于筛选分组后的结果集。通过在SELECT语句中使用GROUP BY和HAVING,可以实现多行去重。示例代码如下: ```sql SELECT column1, column2, column3 FROM table1 GROUP BY column1, column2, column3 HAVING COUNT(*) = 1 ``` 在上述代码中,COUNT(*)用于计算每个分组的行数,通过HAVING子句限制只选择行数为1的分组,从而达到多行去重的效果。 3. 使用ROW_NUMBER()函数:ROW_NUMBER()函数用于给结果集中的行分配一个连续的整数值。可以通过在SELECT语句中使用ROW_NUMBER()函数,并根据需要的列进行排序,然后选择ROW_NUMBER()等于1的行来实现多行去重。示例代码如下: ```sql SELECT column1, column2, column3 FROM ( SELECT column1, column2, column3, ROW_NUMBER() OVER (PARTITION BY column1, column2, column3 ORDER BY column1) as row_num FROM table1 ) t WHERE row_num = 1 ``` 在上述代码中,ROW_NUMBER() OVER (PARTITION BY column1, column2, column3 ORDER BY column1)用于按照列column1, column2, column3进行分组排序和分配行号,然后选择行号等于1的行来实现多行去重。 以上是SQL Server中实现多行去重的常用方法,根据具体情况选择适合的方法进行使用。 ### 回答3: 在SQL Server中,如果需要对多行数据进行去重操作,可以使用以下几种方法: 1. 使用DISTINCT关键字:可以通过在SELECT语句中使用DISTINCT关键字来去重多行数据。例如,如果有一个包含多个列的表格,可以使用SELECT DISTINCT * FROM 表名来获取去重后的结果。 2. 使用GROUP BY子句:可以使用GROUP BY子句来对多行数据进行分组,并在分组的基础上进行去重。例如,如果需要根据某一列的值进行分组,并只保留每组的第一条记录,可以使用以下的SQL查询语句: SELECT 列1, 列2, 列3 FROM 表名 GROUP BY 列1, 列2, 列3 3. 使用窗口函数SQL Server 2005及以上版本支持窗口函数,可以使用窗口函数ROW_NUMBER()来对多行数据进行编号,然后根据编号进行去重。例如,以下的SQL查询语句可以按照某一列的值进行排序,并根据排序结果为每行数据分配一个编号,然后只保留编号为1的行: WITH CTE AS ( SELECT 列1, 列2, 列3, ROW_NUMBER() OVER (PARTITION BY 列1 ORDER BY 列2) AS RN FROM 表名 ) SELECT 列1, 列2, 列3 FROM CTE WHERE RN = 1 总结来说,SQL Server中可以通过DISTINCT关键字、GROUP BY子句和窗口函数等方法实现对多行数据的去重操作。根据实际需求选择合适的方法,并在查询语句中使用相应的语法实现去重效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值