选择工作日MS SQL? [英] Select weekday MS SQL?

查看:104
本文介绍了选择工作日MS SQL?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有工作时间的应用程序...



我需要的是星期六星期日才能使用我的代码



没有

I have app for workers work time...

I need if is Saturday od Sunday to work with my code

Without

CASE WHEN WEEKDAY(a.vrijemeodjave) in (1,7) then 0 else 





代码工作罚款



声明是Microsoft SQL 2016



我有什么试过:





CODE WORKING FINE

Statement is Microsoft SQL 2016

What I have tried:

SELECT a.id, a.redni_broj , a.radnik, isnull(convert(varchar(20), a.vrijemeodjave, 113), '') as vrijemeodjave, convert(varchar(20), b.vrijemeprijave, 113) as vrijemeprijave, 
CASE WHEN WEEKDAY(b.vrijemeprijave) in (1,7) then 0 else (CASE WHEN (DATEDIFF(SECOND, b.vrijemeprijave, a.vrijemeodjave) / 3600) > 8 THEN 8 ELSE(DATEDIFF(SECOND, b.vrijemeprijave, a.vrijemeodjave) / 3600) END) end    AS radni_sati, 
CASE WHEN WEEKDAY(a.vrijemeodjave) in (1,7) then 0 else (CASE WHEN(DATEDIFF(SECOND, b.vrijemeprijave, a.vrijemeodjave) / 3600) > 8  THEN(DATEDIFF(SECOND, b.vrijemeprijave, a.vrijemeodjave) / 3600) - 8  ELSE NULL END) end    AS prekovremeni 
FROM(SELECT id, redni_broj, radnik, vrijemeodjave, ROW_Number() OVER(Partition By id ORDER BY vrijemeprijave) as RowNum 
FROM dbo.prijava_radnika) a INNER JOIN(SELECT id, redni_broj, radnik, vrijemeprijave, (ROW_Number() OVER(Partition By id ORDER BY vrijemeprijave) - 1) as RowNumMinusOne FROM dbo.prijava_radnika) b ON a.id = b.id where 1 = 1 

推荐答案

不确定我是否正确理解了这个问题但您可以使用DATEPART来提取工作日编号。



例如

Not sure if I understand the question correctly but you can use DATEPART to exctract the weekday number.

For example
SELECT DATEPART(weekday, GETDATE())


除了回答1,也许这会让事情变得更清楚:

In addition to answer 1, maybe this will make things clearer:
SELECT
  DATENAME(weekday, a.vrijemeodjave),
  DATEPART(weekday, a.vrijemeodjave)
FROM dbo.prijava_radnika



另见SQL小提琴: SQL Fiddle [ ^ ]


这篇关于选择工作日MS SQL?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆