dongxun3777 2011-12-21 12:42
浏览 63
已采纳

删除重复记录而不创建临时表

I have a table with many duplicate records:

shop
ID     tax_id
1      10
1      10
1      11
2      10
2      12
2      10
2      10

I want to delete all duplicate records without creating a temporary table. After the update query, the table should look like:

shop
ID     tax_id
1      10
1      11
2      10
2      12
  • 写回答

5条回答 默认 最新

  • donglu1973 2011-12-21 12:58
    关注

    Here's an in-place solution (but not one-liner)

    Find out max id:

    select max(id) as maxid 
      from shop;
    

    Remember this value. Let's say it equals to 1000;

    Re-insert unique values, with offset:

    insert into shop (id, tax_id) 
    select distinct id + 1000, tax_id 
      from shop;
    

    Drop old values:

    delete from shop
      where id <= 1000;
    

    Restore normal ids:

    update shop
      set id = id - 1000;
    

    PROFIT!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算