关键词不能为空

当前您在: 主页 > 英语 >

SQL Server - 把星期一(周一)当作每个星期的开始在一年中求取周数=

作者:高考题库网
来源:https://www.bjmy2z.cn/gaokao
2021-02-12 09:17
tags:

-

2021年2月12日发(作者:有道在线词典)


SQL Server -


把星期一


(


周一


)


当作每个星期的开始在一年中求取周数



先感叹一句!好长时间没有更新博客了!偶尔看到一句话,觉 得被电击了



-


庸人败于懒,能人败于傲!



因此,不能再懒惰了!




今天想写一个有关计算



Week


Number


的函数,刚开始觉得应该很简单,凭着感觉七写 八写到最后发现越


写越乱,


到最后搞了快两个小时以为解决了,


结果一测还有好多数据不正确。


非常有挫败感!


感觉很不服气,


觉得很丢人,跑出去站了会,冷静下来,重新拿起纸笔认真的分 析了一下,连写到测试快半个小时还是解决


了。






SQL


Server


中默认情况下 ,每周的开始都是从周日开始算起的。但是在国内也有不一样的要求,比如按


照习惯往往 要求每周从周一算起。这样一来之前在数据仓库中的



Week


Number


可能就不准确了,因为可


能很多时候都是按默认方式来生成



Week


Number


的。




这里有三种方式可以解决这个问题:



第一种方式是直接通过



SET


DATEFIRST


VALUE


来更改重新生成新的



DimDate


,然后每次需要单独计算



Week


Number


的时候根据



Date


Key


关联一下就可以了,


但这样就需要不断



JOIN


DimDate



每一条记


录都要



LookUp


一遍,不太好。



第二种方式就是在存储过程中需要使用到



Week


Number


的时候,就先设置一下



SET


DATEFIRST


然后


在使用



DATEPART()


函数来获取



Week


Number


。这种方式需 要每次都显示的



SET


DATEFIRST


,不太


方便。



第三种方式就是直接写一个函数,每次调用一下就可以了。




关于使用



SET


DATEFIRST



-



的值从



1




7


,即周一到周日,默认值是



7






-- The default first date in a week is Sunday, the value is 7



SELECT



@@DATEFIRST




-- Default DATEFIRST is Sunday



SELECT



DATENAME


(WEEK,


'2013- 12-31'


)


AS


WeekName


-- 53



SELECT



DATENAME


(WEEK,


'2014-01-01'


)


AS


WeekName


-- 1



SELECT


< br>DATENAME


(WEEK,


'2014-01-05 '


)


AS


WeekName


-- 2




-- Change the DATEFIRST to 1, Monday will be the first day of week.



SET


DATEFIRST


1




SELECT



@@DATEFIRST



-- 1




-- After change the DATEFIRST to Monday



SELECT



DATENAME


(WEEK,


'2013-12-31'


)


AS


WeekName


-- 53



SELECT



DATENAME


(WEEK,


'2014-01-0 1'


)


AS


WeekName


-- 1



SELECT



DATENAME


(WEEK,


'2014-01-05'


)


AS


WeekName


-- 1



要注意的是



SET


DATEFIRST


只在当 前执行中有效,


也就说比如新开一个查询页面继续查询



SELECT


@@D


ATEFIRST


则还是显示默认值



7




在创建时间维度的代码中添加



SET


DATEFIRST


1


,表示每周以周一开始。



USE


BIWORK_SSIS


GO



SET


NOCOUNT


ON




--


设置每周的起始天为周一



SET


DATEFIRST


1




IF



OBJECT_ID

< p>
(


'DimDateStartWithMonday'

< br>,


'U'


)


IS



NOT



NULL



DROP



TABLE


DimDateStartWithMonday


GO




CREATE



TABLE


DimDateStartWithMonday


(


DateKey


INT



PRIMARY



KEY


,


FullDate DATE


NOT



NULL


,



[DateName]



NVARCH AR


(


20


),


DayNumberOfWeek


TINYINT



NOT



NULL


,


DayNameOfWeek


NVARCHAR


(

< p>
10


)


NOT



NULL


,


DayNumberOfMonth


TINYINT



NOT



NULL


,


DayNumberOfYear


SMALLINT



NOT



NULL


,


WeekNumberOfYear


TINYINT



NOT



NULL


,


EnglishMonthName


NVARCHAR


(


10


)


NOT



NULL


,


MonthNumberOfYear


TINYINT



NOT



NULL


,


CalendarQuarter


TINYINT



NOT



NULL


,


CalendarSemester


TINYINT



NOT



NULL


,


CalendarYear


SMALLINT



NOT



NULL



)



DECLARE



@StartDate



DATETIME



DECLARE



@EndDate



DATETIME




SELECT



@StartDate



=



'2001-01-01'


,



@EndDate



=



'2035-12-31'




WHILE


(


@StartDate



<=



@EndDate


)


BEGIN




INSERT



INTO


DimDateStartWithMonday


(


DateKey,


FullDate,



[DateName]


,


DayNumberOfWeek,


DayNameOfWeek,


DayNumberOfMonth,


DayNumberOfYear,


WeekNumberOfYear,


EnglishMonthName,


MonthNumberOfYear,


CalendarQuarter,


CalendarSemester,


CalendarYear


)



SELECT



CAST


(


CONVERT


(


VAR CHAR


(


8


),

@StartDate


,


112


)


AS



INT


)


AS


DateKey,



CONVERT


(


VARCHAR


(


10


),


@S tartDate


,


20


)


AS


FullDate,



CONVERT


(


VARCHAR


(


20


),


@S tartDate


,


106


)


AS



[DateName]


,



DATEPART


(DW,


@Star tDate


)


AS


DayNumberOfWeek,



DATENAME


(DW,


@StartDate


)


AS


DayNameOfWeek,



DATENAME

(DD,


@StartDate


)


AS



[DayOfMonth]


,



DATENAME


(DY,


@Star tDate


)


AS



[DayOfYear]


,



DATEPART


(WW,


@Star tDate


)


AS


WeekNumberOfYear,



DATENAME


(MM,


@StartDate

< p>
)


AS


EnglishMonthName,



DATEPART

(MM,


@StartDate


)


AS


MonthNumberOfYear,



DATEPART

(QQ,


@StartDate


)


AS


CalendarQuarter,



CASE



WHEN



DATEPART


(MM,


@StartDate


)


BETWEEN



1



AND



6




THEN



1




ELSE



2




END



AS


CalendarSemester,



DATEPART

(YY,


@StartDate


)


AS


CalendarYear




SET



@StartDate



=



@StartDate



+



1



END



GO


-


-


-


-


-


-


-


-



本文更新与2021-02-12 09:17,由作者提供,不代表本网站立场,转载请注明出处:https://www.bjmy2z.cn/gaokao/642486.html

SQL Server - 把星期一(周一)当作每个星期的开始在一年中求取周数=的相关文章

  • 余华爱情经典语录,余华爱情句子

    余华的经典语录——余华《第七天》40、我不怕死,一点都不怕,只怕再也不能看见你——余华《第七天》4可是我再也没遇到一个像福贵这样令我难忘的人了,对自己的经历如此清楚,

    语文
  • 心情低落的图片压抑,心情低落的图片发朋友圈

    心情压抑的图片(心太累没人理解的说说带图片)1、有时候很想找个人倾诉一下,却又不知从何说起,最终是什么也不说,只想快点睡过去,告诉自己,明天就好了。有时候,突然会觉得

    语文
  • 经典古训100句图片大全,古训名言警句

    古代经典励志名言100句译:好的药物味苦但对治病有利;忠言劝诫的话听起来不顺耳却对人的行为有利。3良言一句三冬暖,恶语伤人六月寒。喷泉的高度不会超过它的源头;一个人的事

    语文
  • 关于青春奋斗的名人名言鲁迅,关于青年奋斗的名言鲁迅

    鲁迅名言名句大全励志1、世上本没有路,走的人多了自然便成了路。下面是我整理的鲁迅先生的名言名句大全,希望对你有所帮助!当生存时,还是将遭践踏,将遭删刈,直至于死亡而

    语文
  • 三国群英单机版手游礼包码,三国群英手机单机版攻略

    三国群英传7五神兽洞有什么用那是多一个武将技能。青龙飞升召唤出东方的守护兽,神兽之一的青龙。玄武怒流召唤出北方的守护兽,神兽之一的玄武。白虎傲啸召唤出西方的守护兽,

    语文
  • 不收费的情感挽回专家电话,情感挽回免费咨询

    免费的情感挽回机构(揭秘情感挽回机构骗局)1、牛牛(化名)向上海市公安局金山分局报案,称自己为了挽回与女友的感情,被一家名为“实花教育咨询”的情感咨询机构诈骗4万余元。

    语文
SQL Server - 把星期一(周一)当作每个星期的开始在一年中求取周数=随机文章