免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3693 | 回复: 8
打印 上一主题 下一主题

【已解决】如何查找 ID 断号 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-07-16 11:28 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2012-07-20 14:03 编辑

+---------+-------------------------------------------------------------+
| page_id | page_title                                                  |
+---------+-------------------------------------------------------------+
|       1 | 首页                                                        |
|       2 | Current_events                                              |
|       3 | Kernel                                                      |
|       4 | Mail                                                        |
|       5 | OMS_Documentations_V0.1.0                                   |
|       6 | Ksh                                                         |
|       7 | Zh-openbsd                                                  |
|       8 | Ldap                                                        |
|       9 | 新手指南                                                    |
|      10 | LaTex                                                       |
|      11 | Desktop                                                     |
|      12 | OMS_Documentations_V0.2beta1                                |
|      14 | 文件归档                                                    |
|      16 | LiveCD                                                      |

需要找到  13,15

论坛徽章:
0
2 [报告]
发表于 2012-07-16 12:24 |只看该作者
select * from (
select page_id-1 as page_id
from tb A
where not exists (select 1 from tb B where A.page_id-1=B.page_id)
)C
where page_id>0

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
3 [报告]
发表于 2012-07-16 13:06 |只看该作者
楼上的方法对于连续的断号就解决不了了。可以考虑用SP;

论坛徽章:
0
4 [报告]
发表于 2012-07-16 14:41 |只看该作者
可以考虑建立一张序列表,然后用left join , not exists就可以解决问题了

论坛徽章:
0
5 [报告]
发表于 2012-07-16 20:34 |只看该作者
写个sp吧,

1. 查出page_id 的最大值
2.搞个游标,做个for

论坛徽章:
0
6 [报告]
发表于 2012-07-17 09:49 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
7 [报告]
发表于 2012-07-17 12:10 |只看该作者
谢谢各位

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
8 [报告]
发表于 2012-07-17 12:33 |只看该作者
不用 sp 不用 for 不用序列表的解决方案,如有连续断号的,可以做改进:
  1. mysql> select * from idlist;
  2. +------+
  3. | id   |
  4. +------+
  5. |    1 |
  6. |    2 |
  7. |    3 |
  8. |    4 |
  9. |    5 |
  10. |    6 |
  11. |    7 |
  12. |    8 |
  13. |    9 |
  14. |   10 |
  15. |   11 |
  16. |   12 |
  17. |   14 |
  18. |   16 |
  19. +------+
  20. 14 rows in set (0.00 sec)

  21. mysql> set @last_id := 0;
  22. Query OK, 0 rows affected (0.00 sec)

  23. mysql>
  24. mysql> select lost_id
  25.     -> from
  26.     -> (
  27.     ->     select if(isnull(@last_id), "xx", if(@last_id = id - 1, 0, 1)) as fla
  28. g, @last_id := id, id - 1 as lost_id
  29.     ->     from idlist
  30.     -> ) as tmp
  31.     -> where flag = 1;
  32. +---------+
  33. | lost_id |
  34. +---------+
  35. |      13 |
  36. |      15 |
  37. +---------+
  38. 2 rows in set (0.00 sec)

  39. mysql>
复制代码

论坛徽章:
8
综合交流区版块每周发帖之星
日期:2015-12-02 15:03:53数据库技术版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-09-14 06:20:00金牛座
日期:2014-10-10 11:23:34CU十二周年纪念徽章
日期:2013-10-24 15:41:34酉鸡
日期:2013-10-19 10:17:1315-16赛季CBA联赛之北京
日期:2017-03-06 15:12:44
9 [报告]
发表于 2012-07-20 13:08 |只看该作者
seesea2517 发表于 2012-07-17 12:33
不用 sp 不用 for 不用序列表的解决方案,如有连续断号的,可以做改进:


嗯,用这样的思想是可以的
参阅
http://www.mysqlops.com/2012/03/06/an_interesting_query.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP