服务器之家

服务器之家 > 正文

在sql Server自定义一个用户定义星期函数

时间:2019-12-14 15:20     来源/作者:MSSQL教程网

2012年刚到,开发的软件使用这个函数发现bug。2012年第一周应该是2012-01-01至2012-01-07,但此函数却把2012-01-08至2012-01-14当作第一周。 

就此bug对此函数修改如下: 

复制代码代码如下:


SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 
ALTER FUNCTION [dbo].[udf_Week] 

@StartYear INT, 
@EndYear INT 

RETURNS @Week TABLE([WeekId] INT IDENTITY(1,1) PRIMARY KEY,[Year] [INT] NULL,[Week] [INT] NULL,[StartDate] [DATETIME] NULL,[EndDate] [DATETIME] NULL) 
AS 
BEGIN 
DECLARE @YearStartDate DATETIME 
DECLARE @YearEndDate DATETIME 
DECLARE @WeekStartDate DATETIME 
DECLARE @WeekEndDate DATETIME 
DECLARE @Weeks INT 

WHILE @StartYear <= @EndYear 
BEGIN 
SET @YearStartDate = CAST((CAST(@StartYear AS VARCHAR(4)) + '-01-01') AS DATETIME) 
SET @YearEndDate= CAST((CAST(@StartYear AS VARCHAR(4))+ '-12-31') AS DATETIME) 
SET @Weeks = 1 

IF DATEPART(DW,@YearStartDate) > 4 
SET @YearStartDate = DATEADD(DAY,(8 - DATEPART(DW,@YearStartDate)) ,@YearStartDate) 
ELSE 
SET @YearStartDate = DATEADD(DAY,(-(DATEPART(DW,@YearStartDate)-1)),@YearStartDate) 

SET @WeekStartDate = @YearStartDate 
SET @WeekEndDate = DATEADD(DAY,6,@WeekStartDate) 
WHILE DATEDIFF(DAY,@WeekStartDate,@YearEndDate) >= 4 
BEGIN 
INSERT INTO @Week([Year],[Week],[StartDate],[EndDate]) VALUES (@StartYear,@Weeks,@WeekStartDate,@WeekEndDate) 
SET @Weeks = @Weeks + 1 
SET @WeekStartDate = @WeekStartDate + 7 
SET @WeekEndDate = @WeekEndDate + 7 
END 
SET @StartYear = @StartYear + 1 
END 
RETURN 
END 

标签:

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
返回顶部