首页 > 数据库技术 > 详细

在论坛中出现的比较难的sql问题:7(子查询 判断某个字段的值是否连续)

时间:2019-12-11 00:55:04      阅读:117      评论:0      收藏:0      [点我收藏+]
原文:在论坛中出现的比较难的sql问题:7(子查询 判断某个字段的值是否连续)

最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了。

所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。


1、求一个聚合的SQL该怎么写

http://bbs.csdn.net/topics/390640648?page=1#post-396068172

有这样的数据
员工    开始日期                     终了日期
A       2013-05-01 00:00:00.000      2013-06-08 00:00:00.000
A       2013-09-02 00:00:00.000      2013-12-31 00:00:00.000
A       2013-09-05 00:00:00.000      NULL


求员工A的所能表示的最大范围的日期,取日期的并集,最后结果应该如下:
员工    开始日期                     终了日期
A       2013-05-01 00:00:00.000      2013-06-08 00:00:00.000
A       2013-09-02 00:00:00.000      NULL

请问谁知道这样的SQL语句该如何写。


我的解法:

  1. ;with t(员工 , 开始日期,终了日期)
  2. as
  3. (
  4. select ‘A‘, ‘2013-05-01 00:00:00.000‘,‘2013-06-08 00:00:00.000‘
  5. union all select ‘A‘,‘2013-09-02 00:00:00.000‘,‘2013-12-31 00:00:00.000‘
  6. union all select ‘A‘,‘2013-09-05 00:00:00.000‘,NULL
  7. union all select ‘A‘,‘2013-09-15 00:00:00.000‘, ‘2013-11-08 00:00:00.000‘
  8. ),
  9. tt
  10. as
  11. (
  12. select 员工,开始日期,终了日期,
  13. (select MIN(t2.开始日期)
  14. from t t2
  15. where t1.员工 = t2.员工
  16. and t1.开始日期 between t2.开始日期 and isnull(t2.终了日期,‘3000-01-01‘)
  17. ) as min_开始日期,
  18. (select max(isnull(t2.终了日期,‘3000-01-01‘))
  19. from t t2
  20. where t1.员工 = t2.员工
  21. and t1.开始日期 between t2.开始日期 and isnull(t2.终了日期,‘3000-01-01‘)
  22. ) as max_终了日期
  23. from t t1
  24. )
  25. select 员工,min_开始日期 as 开始日期,
  26. nullif(max(max_终了日期),‘3000-01-01‘) as 终了日期
  27. from tt
  28. group by 员工,min_开始日期
  29. /*
  30. 员工 开始日期 终了日期
  31. A 2013-05-01 00:00:00.000 2013-06-08 00:00:00.000
  32. A 2013-09-02 00:00:00.000 NULL
  33. */

2、sql中怎么判断某个字段的值是否连续?

http://bbs.csdn.net/topics/390615670

比如:A表的字段AID的值为:1、2、4、5、7、8、10
怎么用sql查询出2、5、8的结果呢?
要查的结果就是查询这组数据从哪里开始不连续的。

我的解法:

  1. create table A(AID int)
  2. insert into A(AID)
  3. select 1 union all
  4. select 2 union all
  5. select 4 union all
  6. select 5 union all
  7. select 7 union all
  8. select 8 union all
  9. select 10
  10. select aid
  11. from
  12. (
  13. select a.aid,
  14. (select min(aid) from a aa where aa.aid > a.aid) min_aid
  15. from A
  16. )a
  17. where aid +1 < min_aid
  18. /*
  19. aid
  20. 2
  21. 5
  22. 8
  23. */




发布了416 篇原创文章 · 获赞 135 · 访问量 94万+

在论坛中出现的比较难的sql问题:7(子查询 判断某个字段的值是否连续)

原文:https://www.cnblogs.com/lonelyxmas/p/12019985.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!