首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TSQL ISO年周数的ISO月份周数

TSQL ISO年周数的ISO月份周数
EN

Stack Overflow用户
提问于 2016-10-04 04:03:48
回答 2查看 1.2K关注 0票数 1

使用TSQL,我需要获得给定ISO年周数在一个月内的ISO周数。

例如:下面的代码将给出12/31/2001的第1周,这是正确的。这是2002年的第一个星期一,也是ISO 2002年的第一天。

代码语言:javascript
复制
select DATEPART(ISO_WEEK, '12-31-2001'); --Week 1 January 2002

我的问题是我怎么.

(1)以ISO周编号为例: ISO年份周编号: 14,表示2016年4月4日(4月第1周)。

(2)现在以ISO年份周编号14为例,返回上述示例的4月月周编号=1。

在SQL Server中似乎没有任何东西可以从ISO年周数中获取ISO月份的Week#。我有一个我写的函数,但它有一些黑客让它工作,但不是100%。

EN

回答 2

Stack Overflow用户

发布于 2016-10-04 05:27:54

我想你想要这样的东西...但是我不确定为什么你需要ISO_WEEK。只需将getdate()替换为您的列。

代码语言:javascript
复制
select datepart(wk, getdate()) - datepart(wk,dateadd(m, DATEDIFF(M, 0, getdate()), 0)) + 1
票数 0
EN

Stack Overflow用户

发布于 2016-10-07 07:25:55

在尝试在函数中获取ISO月周数之后,我决定一个更简单的解决方案是在SQL Sever中创建一个ISO_Calendar表。

我们知道在TSQL中,你可以得到ISO年的周数和一些工作,ISO年的数字。ISO月份周数字则是另一回事。

通过填充ISO月份编号以外的所有列,我使用2000到2040年的数据构建了如下所示的表。然后,在第二次遍历时,我遍历了表,并根据星期一日期中的Month#设置了ISO月份编号。

现在,如果我想获得某个日期的ISO月份号,我可以检查@Date介于星期一和星期日之间。在我的例子中,我只关心周一到周五之间的日期,因为这是一个股票分析网站。

代码语言:javascript
复制
select @ISOMonthWeekNo = c.ISOMonthWeekNo
from ISO_Calendar c
where @TransDate between c.Monday and c.Sunday;

优点是表是一次性构建的,更容易验证数据的准确性。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39839529

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档