首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >平日与Datepart个案

平日与Datepart个案
EN

Stack Overflow用户
提问于 2014-04-14 13:18:42
回答 1查看 1.3K关注 0票数 0

有什么想法吗?下面的代码有什么问题?

我正在尝试写一个case语句,在星期一返回今天的日期,否则,如果今天的日期在星期一,则从表中取最大日期

谢谢

代码语言:javascript
复制
SELECT 
CASE [EffectiveDate]
When datepart(weekday,getdate()) = 1  Then cast(getdate() as date)
Else max ([EffectiveDate])
End,
FROM
[ARCDAL01PR].[ArcTimeSeries].[arc_ts_data].[PriceCurveData]
WHERE
[CurveName] = 'G_H_TTF.EUR'
EN

回答 1

Stack Overflow用户

发布于 2014-04-14 13:24:27

代码语言:javascript
复制
SELECT 
CASE [EffectiveDate]
When datepart(weekday,getdate()) = 2 Then cast(getdate() as date)
Else max ([EffectiveDate])
End,
FROM
[ARCDAL01PR].[ArcTimeSeries].[arc_ts_data].[PriceCurveData]
WHERE
[CurveName] = 'G_H_TTF.EUR

星期一应该是一周的第二天。最后,如果使用Server 2012,您可以尝试这样做。

代码语言:javascript
复制
SELECT 
CASE [EffectiveDate]
When weekday(getdate(),2) = 1  Then cast(getdate() as date)
Else max ([EffectiveDate])
End,
FROM
[ARCDAL01PR].[ArcTimeSeries].[arc_ts_data].[PriceCurveData]
WHERE
[CurveName] = 'G_H_TTF.EUR

更新

代码语言:javascript
复制
SELECT 
CASE
When datepart(weekday,getdate()) = 2 Then cast(getdate() as date)
Else max ([EffectiveDate])
End as [EffectiveDate]
FROM
[ARCDAL01PR].[ArcTimeSeries].[arc_ts_data].[PriceCurveData]
WHERE
[CurveName] = 'G_H_TTF.EUR'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23061198

复制
相关文章

相似问题

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