博客
关于我
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/

    你可能感兴趣的文章
    openstack--memecache
    查看>>
    openstack-keystone安装权限报错问题
    查看>>
    openstack下service和endpoint
    查看>>
    Openstack企业级云计算实战第二、三期培训即将开始
    查看>>
    OpenStack创建虚拟机实例实战
    查看>>
    OpenStack安装部署实战
    查看>>
    OpenStack架构
    查看>>
    OpenStack版本升级与故障排查实战
    查看>>
    OpenStack的基本概念与架构详解
    查看>>
    Openstack的视频学习
    查看>>
    openstack虚拟机迁移live-migration中libvirt配置
    查看>>
    ORACEL学习--理解over()函数
    查看>>
    oracle 10g的安装配置
    查看>>
    Oracle 11g数据库安装和卸载教程
    查看>>
    ORACLE Bug 4431215 引发的血案—原因分析篇
    查看>>
    oracle dblink 创建使用 垮库转移数据
    查看>>
    oracle dblink结合同义词的用法 PLS-00352:无法访问另一数据库
    查看>>
    Oracle dbms_job.submit参数错误导致问题(ora-12011 无法执行1作业)
    查看>>
    oracle dg switchover,DG Switchover fails
    查看>>
    Oracle EBS-SQL (BOM-15):检查多层BOM(含common BOM).sql
    查看>>