SQLserver求去年同期,比如说现在是12月2号   要算去年一月到去年12月2号的数据

SQL   server求去年同期,比如说现在是12月2号   要算去年一月到去年12月2号的数据,我现在写了一个是到去年本月底的

SELECT SUM

( PMCSUM+TRADITIONSUM ) AS PMCSUM ,

INPUTTIME

FROM

DBO.ONCONTRACT 

WHERE

LEFT ( CONVERT ( VARCHAR, INPUTTIME, 112 ), 4 ) = LEFT ( CONVERT ( VARCHAR, DATEADD( YEAR, - 1, GETDATE( ) ), 112 ), 4 ) 

AND SUBSTRING ( CONVERT ( VARCHAR, INPUTTIME, 112 ), 5, 2 ) <= SUBSTRING ( CONVERT ( VARCHAR, GETDATE( ), 112 ), 5, 2 ) 

GROUP BY INPUTTIME


用户K0035705 发布于 2020-12-2 10:05 (编辑于 2020-12-17 15:21)
1min目标场景问卷 立即参与
回答问题
悬赏:3 F币 + 添加悬赏
提示:增加悬赏、完善问题、追问等操作,可使您的问题被置顶,并向所有关注者发送通知
共2回答
最佳回答
0
鱼仔仔家的荣荣Lv4初级互助
发布于2020-12-2 10:52

CONVERT ( VARCHAR, INPUTTIME, 112 ) <= CONVERT ( VARCHAR, dateAdd(yy,-1,getdate() ), 112 )

最佳回答
0
张洪威Lv6高级互助
发布于2020-12-2 10:13(编辑于 2020-12-2 10:18)

where 日期字段 between   '${CONCATENATE(year(today())-1,"-01-01")}'  and '${YEARDELTA(today(),-1)}'

在帆软里面的做法


sql server做法,电脑上没sql server环境,需不需要convert转格式你可以自己试下。

where year(日期字段)+1=year(getdate()) and 日期字段<=dateadd(m,-12,getdate())

  • 4关注人数
  • 1332浏览人数
  • 最后回答于:2020-12-17 15:21
    请选择关闭问题的原因
    确定 取消
    返回顶部