zoukankan      html  css  js  c++  java
  • SQL顺序列找出断号


    select id from info

    id
    -----------
    1
    2
    3
    5
    6
    7
    8
    10
    11
    12
    15

    (11 行受影响)

    方法一:

    select (select max(id)+1 from Info where id<a.id) as beginId,(id-1) as endId
    from Info a 
    where 
    a.id>(select max(id)+1 from Info where id<a.id)

    beginId     endId
    ----------- -----------
    4           4
    9           9
    13         14

    (3 行受影响)

    方法二:

    select beginId,(select min(id)-1 from info where id > beginId) as endId 
    from (  
    select id+1 as beginId from info where id+1 not in (select id from info) and id < (select max(id) from info)  
    ) as t

    beginId     endId
    ----------- -----------
    4           4
    9           9
    13          14

    (3 行受影响)


    说明:

    1、查找结果的两列是断号的区间,如果beginId=endId,则表示缺少该号码,否则表示缺少beginId ~ endId;

    2、如果号码1不存在,区间1 ~ select min(id)-1 from info 将无法找出

  • 相关阅读:
    Celery异步框架
    彻底理解cookie,session,token
    消息队列
    pip源、搭建虚拟环境、git
    全文检索
    redis高级
    redis基础
    基本数据结构和算法(python代码实现算法)
    MySQL数据库高级
    MySQL数据库进阶
  • 原文地址:https://www.cnblogs.com/Yellowshorts/p/3451498.html
Copyright © 2011-2022 走看看