博客
关于我
SQL练习42:删除emp_no重复的记录,只保留最小的id对应的记录。
阅读量:585 次
发布时间:2019-03-11

本文共 716 字,大约阅读时间需要 2 分钟。

SQL练习42:删除emp_no重复的记录,只保留最小的id对应的记录

ngemp_no重复的记录,只保留最小的id对应的记录。针对这个问题,我可以通过以下步骤来解决:

首先,查看数据库中有哪些emp_no记录是重复出现的。在titles_test表中,我发现:

  • emp_no=10001 出现了两次,分别是 id=1 和 id=5
  • emp_no=10002 出现了两次,分别是 id=2 和 id=6
  • emp_no=10003 出现了两次,分别是 id=3 和 id=7
  • emp_no=10004 出现了一次,id=4

接下来,我需要从中只保留每个emp_no对应的最小的id记录。

为了选择每个emp_no对应的最小的id,我可以使用GROUP BY语句和MIN()函数。具体步骤如下:

  • 首先,使用GROUP BY emp_no,将记录按emp_no分组。
  • 在每个组内,使用MIN(id)函数来获取最小的id。
  • 此外,我需要删除所有不符合上述最小id记录的数据。因此,我使用了 DELETE FROM 关键字,并使用子查询来确定哪些记录需要删除。

    为了确保子查询结果正确,我使用了一个 alias,这样可以避免与原表直接操作带来的问题。具体的实现步骤如下:

  • 选择每个emp_no对应的最小id,并为结果起 alias。例如,t1。
  • 在主查询中,执行删除操作,只删除不包含在t1中的id记录。
  • 通过这种方法,我确保每个emp_no只保留一次最小的id记录。

    最终操作如下:

    请注意,子查询的结果必须正确使用 alias,否则可能导致错误。

    最终,运行删除操作后,titles_test表将只包含每个emp_no对应的最小id记录。

    转载地址:http://bojtz.baihongyu.com/

    你可能感兴趣的文章
    oracle 使用leading, use_nl, rownum调优
    查看>>
    oracle 修改字段类型方法
    查看>>
    Oracle 写存储过程的一个模板还有一些基本的知识点
    查看>>
    Oracle 创建 DBLink 的方法
    查看>>
    oracle 创建字段自增长——两种实现方式汇总
    查看>>
    Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
    查看>>
    oracle 可传输的表空间:rman
    查看>>
    Oracle 启动监听命令
    查看>>
    oracle 学习
    查看>>
    ORACLE 客户端工具连接oracle 12504
    查看>>
    oracle 查询clob
    查看>>
    oracle 行转列
    查看>>
    Oracle 表
    查看>>
    Oracle 递归
    查看>>
    oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
    查看>>
    oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>