记得以前有个同事问过我这个,说是以前面试的时候碰到的问题,下面我介绍三种方法。

首先我们在这里创建一个测试表添加相应的测试数据。

create table test  (id number,name varchar(10));
  insert into  test values(1,'liufang');
  insert into  test values(2,'xiaozhang');
  insert into  test values(3,'dawei');
  insert into  test values(4,'laotan');
  insert into  test values(5,'laotan');
  insert into  test values(6,'laotan');
  insert into  test values(7,'dawei');

1、根绝name相同 ID不同来的方式来判断(id必须唯一)

delete from test a where exists (select null from test b where b.name=a.name and b.id>a.id);

2、用rowid 来代替其中的id,比上面的方法更适用,没有字段唯一限制

delete from test a where exists (select null from test b where b.name=a.name and b.rowid>a.rowid);

3、  通过分析函数根据name 分组生成序号,然后删除序号大于1 的数据

(注:rder by 2,3根据查询的第二第三个字段升序排序查询)

select  rowid as rid,name,row_number() over(partition by name order by id) from test order by 2,3;

分析函数会吧对应名称相同的字段出现的次数记录下来,把对应次数大于1 的数据删除即可

分析函数:ROW_NUMBER() OVER (partition by name order by name)  简单的说row_number()从1开始,为每一条分组记录返回一个数字,

这里的ROW_NUMBER() OVER (partition by name order by name) 是先把name列升序,再为降序以后的没条name记录返回一个序号,

delete from test
    where rowid in (select rowid
                      from (select rowid as rid,
                                   row_number() over(partition by name order by id) as seq
                              from test)
                     where seq > 1);

最新文章

  1. 如何用Web技术开发Windows Form应用
  2. [Asp.net 5] Logging-日志系统的基本架构(上)
  3. Universal JS module loader
  4. SQL 基础:Select语句,各种join,union用法
  5. C# 学习之旅(3) --- 会说话的简易计算器
  6. [转]Hulu 2013北京地区校招笔试题
  7. 穿透的 div ( pointer-events )
  8. GoLang获取struct的tag
  9. Java 水仙花数
  10. 使用VS Code从零开始开发调试.NET Core 1.1
  11. .NET Core多平台项目模板eShopOnContainers编译手记
  12. 大道至简第一章Java伪代码读后感
  13. mysql默认安装目录说明
  14. [Swift]LeetCode843. 猜猜这个单词 | Guess the Word
  15. 一个类是怎么被JVM执行的
  16. UE4外包团队:更新一下UE4和Unity3D案例
  17. bzoj2124: 等差子序列线段树+hash
  18. python基础 ---- 使用pyCharm 调试
  19. 【读书笔记】Linux内核设计与实现(第十八章)
  20. 第3章 文件I/O(8)_贯穿案例:构建标准IO函数库

热门文章

  1. Android入门开发之SD卡读写操作(转)
  2. Vs2010工具栏显示“开始执行“按钮
  3. 长按事件jquery mobile
  4. 几种方式实现Javaweb页面跳转
  5. 从客户端(CourseIssueContent="<P>财务审计师岗位认证招生简章<BR>...")中检测到有潜在危险的 Request.Form 值。
  6. 01 HTML基础
  7. Java基础语法的学习
  8. JS(获得当前时间并且用2015-01-01格式表示)
  9. set UVA 11136 Hoax or what
  10. BFS HDOJ 2102 A计划