Foxtable(狐表)用户栏目专家坐堂 → 如何用sql语句找出不上班的时段?


  共有3046人关注过本帖树形打印复制链接

主题:如何用sql语句找出不上班的时段?

帅哥哟,离线,有人找我吗?
有点蓝
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/13 23:07:00 [显示全部帖子]

select * from 排班表 where 工作起始日 >='2019-01-01' and工作起始日 <='2019-02-28'  or 工作起始日 >='2019-06-01' and工作起始日 <='2019-07-31'  or .....

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 9:06:00 [显示全部帖子]

放到数据库执行,如果不出错,肯定没有符合条件的数据

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 9:41:00 [显示全部帖子]

select * from {排班表} where (工作起始日期 >= #2019-01-01# and 工作结束日<=#2019-02-28#)  or (工作起始日期 >= #2019-06-01# and 工作结束日期 <= #2019-07-31#)  or (工作起始日期 >= #2019-12-01# and 工作结束日期 <= #2019-12-31#)

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 11:01:00 [显示全部帖子]

上传实例测试

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 11:58:00 [显示全部帖子]

要得到什么结果?

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 12:06:00 [显示全部帖子]

意思是添加一个列,标记这个时间段是否需要上班?

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 12:10:00 [显示全部帖子]

那还是没搞懂什么意思,就上传的实例,怎么计算最后得出什么结果?

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 14:50:00 [显示全部帖子]

Select (Select isnull(max(dateadd(d,1,工作结束日期)),convert(nvarchar(4),b.工作起始日期,120) + '-01-01') from 排班表 as a where a.工作结束日期 < b.工作起始日期) as 工作起始日期,
dateadd(d,-1,b.工作起始日期) As 工作结束日期 
from (select 工作起始日期 from 排班表 ) as b
union
Select dateadd(d,1,b.工作结束日期 ) As 工作起始日期,
(Select isnull(max(dateadd(d,-1,工作起始日期)),convert(nvarchar(4),b.工作结束日期 ,120) + '-12-31') from 排班表 as a where a.工作起始日期 > b.工作结束日期 ) as 工作起始日期
from (select 工作结束日期  from 排班表 ) as b


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105926 积分:538693 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/15 20:50:00 [显示全部帖子]

这种时间有交叉的,建议遍历所有行处理。没有办法一条SQL处理

 回到顶部