如何以Mon yyyy格式获得下个月?

时间:2014-03-12 10:16:33

标签: sql sql-server sql-server-2008 datetime

我有一个表格,日期为SaleDate,格式如下

##SaleDate##
_________
Oct 13  
--------
Nov 13  
--------  
Dec 13  
-------- 
Jan 14  
--------  

如何从之前的日期格式中获取下个月?

2 个答案:

答案 0 :(得分:0)

通过设置最小和最大日期,您可以获得如下所示的日期列表

       DECLARE @OldestDate DATE
    DECLARE @maxDate DATE 
    SET @OldestDate = '09/29/2013' -- (SELECT MIN(SALEDATE) FROM YOURTABLE)
    SET @maxDate = '12/19/2014' -- (SELECT MAX(SALEDATE) FROM YOURTABLE)

 ; WITH dates([DateCounter]) AS 
  (
    SELECT @OldestDate AS [DateCounter] 
    UNION ALL 
    SELECT DATEADD(month,+1,[DateCounter])
    FROM DATES 
    WHERE [DateCounter] < CAST(@maxDate AS DATE)
  )

    SELECT LEFT(DATENAME(MONTH,[DateCounter]),3) + ' ' + DATENAME(YEAR,[DateCounter])
    FROM dates
    OPTION (MAXRECURSION 0) 

以下是SQLFiddler

上的工作示例

答案 1 :(得分:0)

使用一些冗长的内联函数:

DECLARE @V VARCHAR(6)
SET @V = 'Jan 14'

SELECT RIGHT(CONVERT(VARCHAR(9),DATEADD(m,1,CONVERT(DATETIME,'01 ' + @V,106)),6),6)


SELECT RIGHT(
    CONVERT(
        VARCHAR(9),
            DATEADD(m,1,CONVERT(DATETIME,'01 ' + SaleDate,106))
        ,6)
 ,6)
FROM YourTable