找回密码
 立即注册

QQ登录

只需一步,快速开始

跷跷板

中级会员

87

主题

231

帖子

992

积分

中级会员

积分
992

[资源分享] MSSQL 生成日期

跷跷板
中级会员   /  发表于:2022-8-27 09:23  /   查看:1967  /  回复:0
-生成日期表

CREATE   TABLE   [dbo].[T_Calendar]   (
      [time_id]   [int]   IDENTITY   (1,   1)   NOT   NULL   ,
      [the_date]   [date]   NULL   ,
      [the_day]   [nvarchar]   (15)   NULL   ,
      [the_month]   [nvarchar]   (15)   NULL   ,
      [the_year]   [smallint]   NULL   ,
      [day_of_month]   [smallint]   NULL   ,
      [holiday_type]   [int]      NULL
)   ON   [PRIMARY]

-- 再执行存储过程
DECLARE   @WeekString   varchar(12),
@dDate   SMALLDATETIME,
@sMonth   varchar(20),
@iYear   smallint,
@iDayOfMonth   smallint,
@iWeekOfYear   smallint,
@iMonthOfYear   smallint,
@sQuarter   varchar(2),
@sSQL   varchar(100),
@adddays   int

SELECT   @adddays   =   1   --日期增量(可以自由设定)
SELECT   @dDate   =   '01/01/2022 '   --开始日期

WHILE   @dDate   <=   '12/31/2022 '     --结束日期
BEGIN

      SELECT   @WeekString   =   DATENAME   (dw,   @dDate)
      SELECT   @sMonth=DATENAME(mm,@dDate)
      SELECT   @iYear=   DATENAME   (yy,   @dDate)
      SELECT   @iDayOfMonth=DATENAME   (dd,   @dDate)
      SELECT   @iWeekOfYear=   DATENAME   (week,   @dDate)
      SELECT   @iMonthOfYear=DATEPART(month,   @dDate)
      SELECT   @sQuarter   =   'Q '   +     CAST(DATENAME   (quarter,   @dDate)as   varchar(1))

      INSERT   INTO   T_Calendar(the_date,   the_day,   the_month,   the_year,
      day_of_month
      )   VALUES
      (@dDate,   @WeekString,   @sMonth,   @iYear,   @iDayOfMonth)
      SELECT   @dDate   =   @dDate   +   @adddays
END
GO


0 个回复

您需要登录后才可以回帖 登录 | 立即注册
返回顶部