博客
关于我
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从11g导出后导入10g
    查看>>
    oracle从备份归档日志的方法集中回收
    查看>>
    oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
    查看>>
    Oracle修改字段类型
    查看>>
    Oracle修改表或者字段的注释
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    Oracle内存结构详解(四)--Oracle SGA其他组成部分
    查看>>
    Oracle函数与存储过程和程序包
    查看>>
    Oracle分析函数之LEAD和LAG
    查看>>
    Oracle分组取前n条记录
    查看>>
    Oracle创建database link(dblink)和同义词(synonym)
    查看>>
    oracle创建数据库的步骤
    查看>>
    Oracle创建用户、角色、授权、建表
    查看>>
    Oracle创建用户与授予表空间与权限
    查看>>
    oracle创建表(并且实现ID自增)
    查看>>
    oracle删除重复数据保留第一条记录
    查看>>
    oracle判断空值的函数nvl2,【PL/SQL】 NVL,NVL2,COALESCE 三种空值判断函数
    查看>>
    Oracle发布VirtualBox 7.1稳定版!支持ARM、优化了UI、支持Wayland等
    查看>>
    oracle启动三步
    查看>>
    oracle启动关闭服务,启动关闭oracle服务.bat
    查看>>