重复的2列数据,如何只保留一条记录呢

szlixiaolong 2016-06-02 01:38:49
flow_id sheet_no item_no
2014576 DI0000061605254248 3002889
2035489 DI0000061605254248 3002889


重复的2列是sheet_no,item_no,如何保留一条记录呢?
...全文
109 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
szlixiaolong 2016-06-02
  • 打赏
  • 举报
回复
谢谢您们的指导。
卖水果的net 版主 2016-06-02
  • 打赏
  • 举报
回复
我怎么感觉,你是 2000 的库;那就得用 8# 大版的方法了;
szlixiaolong 2016-06-02
  • 打赏
  • 举报
回复
引用 6 楼 wmxcn2000 的回复:

create table test(flow_id int,sheet_no varchar(30),item_no varchar(10))
go
insert into test values
(2014576,'DI0000061605254248','3002889'),
(2035489,'DI0000061605254248','3002889')
go
with m as 
(select row_number() over(partition by sheet_no,item_no order by flow_id) rn,*
from test
)
delete m where rn > 1
go
select * from test 
go
drop table test 
go



(2 行受影响)

(1 行受影响)
flow_id     sheet_no                       item_no
----------- ------------------------------ ----------
2014576     DI0000061605254248             3002889

(1 行受影响)


消息 2714,级别 16,状态 6,第 1 行 数据库中已存在名为 'test' 的对象。 消息 170,级别 15,状态 1,第 2 行 第 2 行: ',' 附近有语法错误。 消息 156,级别 15,状态 1,第 2 行 在关键字 'with' 附近有语法错误。 消息 195,级别 15,状态 10,第 3 行 'row_number' 不是可以识别的 函数名。 (0 行受影响)
中国风 2016-06-02
  • 打赏
  • 举报
回复
--删除:
delete a from tablename as a where exists(select 1 from tablename where sheet_no=a.sheet_no and item_no=a.item_no and flow_id>a.flow_id)

--只时查询--用group by

select min(flow_id) as flow_id,sheet_no ,item_no from tablename group by sheet_no ,item_no
szlixiaolong 2016-06-02
  • 打赏
  • 举报
回复
引用 6 楼 wmxcn2000 的回复:

create table test(flow_id int,sheet_no varchar(30),item_no varchar(10))
go
insert into test values
(2014576,'DI0000061605254248','3002889'),
(2035489,'DI0000061605254248','3002889')
go
with m as 
(select row_number() over(partition by sheet_no,item_no order by flow_id) rn,*
from test

数据库是SQL 2005,可以用于你的语句吗?
)
delete m where rn > 1
go
select * from test 
go
drop table test 
go



(2 行受影响)

(1 行受影响)
flow_id     sheet_no                       item_no
----------- ------------------------------ ----------
2014576     DI0000061605254248             3002889

(1 行受影响)


数据库是SQL 2005的。
卖水果的net 版主 2016-06-02
  • 打赏
  • 举报
回复

create table test(flow_id int,sheet_no varchar(30),item_no varchar(10))
go
insert into test values
(2014576,'DI0000061605254248','3002889'),
(2035489,'DI0000061605254248','3002889')
go
with m as 
(select row_number() over(partition by sheet_no,item_no order by flow_id) rn,*
from test
)
delete m where rn > 1
go
select * from test 
go
drop table test 
go



(2 行受影响)

(1 行受影响)
flow_id     sheet_no                       item_no
----------- ------------------------------ ----------
2014576     DI0000061605254248             3002889

(1 行受影响)


Ginnnnnnnn 2016-06-02
  • 打赏
  • 举报
回复
用row_number() 排个序分组,然后删除就可以了
szlixiaolong 2016-06-02
  • 打赏
  • 举报
回复
引用 1 楼 wmxcn2000 的回复:
是查询时只出一行,还是想删除一条?
想删除一条 例如保留这一行数据,2014576 DI0000061605254248 3002889 或者 保留这一行数据,2035489 DI0000061605254248 3002889
szlixiaolong 2016-06-02
  • 打赏
  • 举报
回复
引用 1 楼 wmxcn2000 的回复:
是查询时只出一行,还是想删除一条?
例如保留这一行数据,2014576 DI0000061605254248 3002889 或者 保留这一行数据,2035489 DI0000061605254248 3002889
szlixiaolong 2016-06-02
  • 打赏
  • 举报
回复
引用 1 楼 wmxcn2000 的回复:
是查询时只出一行,还是想删除一条?
想删除一条
卖水果的net 版主 2016-06-02
  • 打赏
  • 举报
回复
是查询时只出一行,还是想删除一条?
PowerBI系之Power Query专题1.  获取数据 数据源种类介绍和获取Excel数据源输入数据和拷贝数据:创建辅助表解析Json/XML数据格式获取Web网页数据和URL添加动态参数连接数据的四种模式:Import、DirectQuery、Live Connection、Dual双 属于混合模式连接数据库:Sql server、 Mysql(直连但是必须先安装一个mysql插件)DirectQuery直连查询:Sql serverODBC方式获取数据表关联或多个Sql或调用存储过程获取数据SQL中动态传参和自定义函数: sql中使用参数或数据库名称使用参数连接Sharepoint和OneDrive数据源连接Dataset和Dataflow 替换本地数据源为Sharepoint数据源并保留数据处理操作 终止当前数据刷新Loading:Cancel Query数据源设置-重置数据连接凭证PBIDS连接数据源创建和使用报表模块(输入或值表)利用报表模板和参数控制线下报表数据权限DirectQuery启用自动页面刷新和更改检测管理聚合表提高DirectQuery查询性能动态M查询参数提高DirectQuery查询性能添加数据刷新时间 DateTime.LocalNow()和Getdate()2.  数据清洗和M语言M语言和官方文档介绍PowerQuery中查阅M函数:=#shared, Ctrl+Space提示数据清洗之常用技能:提升标题、更改数据类型、保留删除错误或空行,删除重复项、选择和删除、填充单元格、合并、拆分、提取、替换、条件替换、添加自定义,添加条件、添加索引、分组、添加年月日、追加和合并查询透视和逆透视以及转置合并单元格的Excel文件处理导入文件夹中多Excel文件并合并解决多文件合并中顺序不一致使用参数和函数批量导入文件 文本中提取中文、英文、数字等处理双引号转义 拆分详解解决名改变错误解决丢失错误动态显示、排序和重命名为所有名添加前缀名字母大写和分隔符调整Trim标题中的多余空格如何处理load数据错误为什么load的Excel数据有null空行为什么load的Excel数据标题在第二行灵活添加占位符规范同类相似数据数据按多排序为分组添加Index序号分组内值合并诊断工具分析数据处理过程PowerQuery小技巧分享 新冠病例活动轨迹地图标识 

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧