• 如何在数据表当中找出被删掉的数据行ID


      这个问题是一年前我刚步入IT行业的一个面试题,当时抓破头皮都想不到的问题,但现在回想过去自身不禁感到可笑,不多扯直接写解决方案。如何在数据表当中找出被删掉的数据行ID,意思是:在一堆的数据当中,让你找出数据存在间隔的那些数据行的ID(先不考虑两个数据行中存在多个间隔的情况)。

      

      

      可见ID=14那条数据行正是我要们寻找的,对于这种情况,可用自查询方式处理:

    select ID,New_ID,(New_ID - ID -1) as '存在的间隔数量',ID+1 as '被删除的行ID'
    from
    (
    select ID,New_ID=(
    select min(b.ID) id
    from FamilyImages b
    where b.id > a.id
    ) 
    from FamilyImages a
    ) c
    where ID+1 <> New_ID
    

     查询结果:

      

       那么若数据行之间的间隔存在多个的情况怎么办,其实你可留意第三个字段:“存在的间隔数量”,若存在多个,可考虑循环拼接字符串,放入第四个字段:“被删除的行ID”就可以了,这是一个思路。

       希望这篇文章能给大家帮助,若存在不足,请留言赐教。

       A young ilder ~ an old beggar !

  • 相关阅读:
    unix文件权限
    jira部署,主机迁移,数据库迁移,jira
    c函数习记
    常用软介质下载
    Matlab interpgui
    LightOJ 1422
    【CODEFORCES】 A. Keyboard
    leetcode 230: Kth Smallest Element in a BST
    Vertica7 Native Connection Load Balance
    vlc模块间共享变量
  • 原文地址:https://www.cnblogs.com/YangJianhui/p/9162605.html
Copyright © 2020-2023  润新知