好问题
Good  Question
  • 首 页
  • 问题
    • PHP
    • JAVA
    • CPlusPlus
    • C#
    • SQL
  • 关 于
  • 联 系
如何删除重复的行? 关闭 返回上一级  

如何删除重复的行?
+ 查看更多

发布日期:2018-02-24 16:59
分类:SQL
浏览次数:40
从比较大的表格(300000行以上)中删除重复行的最佳方式是什么呢?
当然,由于行的ID标识字段的存在,行不会轻易地重复。
MyTable
-----------
RowID int not null identity(1,1) primary key,
Col1 varchar(20) not null,
Col2 varchar(2048) not null,
Col3 tinyint not null

回答

假设表格中没有空的内容,你通过特殊的列进行分组,选择最小(或最大)的行的ld作为保留行。然后,只需要删除没有id的行的所有内容。
DELETE FROM MyTable
LEFT OUTER JOIN (
   SELECT MIN(RowId) as RowId, Col1, Col2, Col3 
   FROM MyTable 
   GROUP BY Col1, Col2, Col3
) as KeepRows ON
   MyTable.RowId = KeepRows.RowId
WHERE
   KeepRows.RowId IS NULL

如果你有一个全局唯一标识符而不是一个整数,你可以用
CONVERT(uniqueidentifier, MIN(CONVERT(char(36), MyGuidColumn)))
代替
MIN(RowId)
上一篇如何SQL语句中使用IF…THEN?
如何在单个SQL INSERT语句插入多行?下一篇
下一篇如何在单个SQL INSERT语句插入多行?

最新文章

  • 函数`__construct`用来干嘛的
    发布日期:2018-03-26
  • 通过访客的IP得到他们的地区
    发布日期:2018-03-26
  • 合并两个PHP对象的最好的方法是什么?
    发布日期:2018-03-26
  • 该如何把一该如何把一个对象转化成数组?
    发布日期:2018-03-26
  • 什么是输出缓冲区?
    发布日期:2018-03-26
  • 在PHP中怎么把用逗号分隔的字符串分隔在一个数组里?
    发布日期:2018-03-26
  • 在PHP中使用foreach循环时查找数组的最后一个元素
    发布日期:2018-03-26
关于好问
收集整理一些有用的问题和回答,造福中国的程序旺和IT喵们!
友情链接
起飞页 
相关信息
版权声明
Copyright © 2016 - 2017  苏州卡达网络科技有限公司 好问 GOODQ.TOP 备案号:苏ICP备09008221号-5