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


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

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

帅哥,在线噢!
有点蓝
  21楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105947 积分:538804 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 12:06:00 [只看该作者]

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

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


加好友 发短信
等级:九尾狐 帖子:2180 积分:13804 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2020/3/14 12:09:00 [只看该作者]

不用,我只想要 不上班的时段
[此贴子已经被作者于2020/3/14 12:09:44编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  23楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105947 积分:538804 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/14 12:10:00 [只看该作者]

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

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


加好友 发短信
等级:九尾狐 帖子:2180 积分:13804 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2020/3/14 12:23:00 [只看该作者]

不好意思,我增加一个表你就明白了
现在有个排班表 ,我想统计2019-01-01到2019-12-31 年全年的空闲时段,就是得出第二个表
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目7.table

 

 回到顶部
帅哥哟,离线,有人找我吗?
fox-man
  25楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:250 积分:2725 威望:0 精华:0 注册:2014/3/11 12:11:00
  发帖心情 Post By:2020/3/14 13:40:00 [只看该作者]

这个要先把全年的日期列出来,再结合排班表进行对比统计出不上班的时间段.你用的是sql外部数据源吗?如果是外部数据源使用9楼代码.

 回到顶部
帅哥,在线噢!
有点蓝
  26楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105947 积分:538804 威望: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


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


加好友 发短信
等级:九尾狐 帖子:2180 积分:13804 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2020/3/14 17:29:00 [只看该作者]

蓝大师 ,再请教一下:   
1 我加一个字段 姓名 ,怎么输出?

图片点击可在新窗口打开查看此主题相关图片如下:1.png
图片点击可在新窗口打开查看

2  这段代码只有这2条数据,运行正常,我加了一条记录,运行结果就不对了

图片点击可在新窗口打开查看此主题相关图片如下:2.png
图片点击可在新窗口打开查看



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


加好友 发短信
等级:九尾狐 帖子:2180 积分:13804 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2020/3/15 10:17:00 [只看该作者]

自己顶一下

 回到顶部
帅哥,在线噢!
有点蓝
  29楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:105947 积分:538804 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/3/15 20:50:00 [只看该作者]

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

 回到顶部
总数 29 上一页 1 2 3