jc-dsa 2019-07-15 11:31 采纳率: 62.5%
浏览 394
已采纳

SQL server2008r2 怎么删除一个表内得重复项

有一个100万得表1,里面整行重复的有12万,第一列重复(其他不重复)的有15万

怎么删掉这12万和15万条只留下唯一得

表1

  • 写回答

5条回答 默认 最新

  • 张朋举Biz 2019-07-16 11:18
    关注

    无id号的情况下,删除数据库的特定行
    很明显整行重复的在第一列重复的,删除第一列重复的即可

    删除第一列重复

    with t1(rownum) as ( select row_number () over(PARTITION BY aa order by aa) from 表1)
    delete from t1 where t1.rownum>1
    select * from 表1
    

    删除整行重复

    with t1(rownum) as ( select row_number () over(PARTITION BY aa,bb,省,市 order by aa) from 表1)
    delete from t1 where t1.rownum>1
    select * from 表1
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?