亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

初學者必讀:精講SQL中的時間計算語句

2024-07-21 02:44:34
字體:
來源:轉載
供稿:網友

問:請問,如何計算一個表中的周起始和截止日期并寫到表字段中? 我要從一個表向另一個表導入數據,并進行轉換,用的是VB 。


我現在有有一個表 主要字段有

time_id int

time_date datetime

year int

week_of_year int

day nvarhar

想要轉換成另外一張表

time_id int

time_date datetime

year int

week_of_year nvarchar

原來的表內容是

--------------------

1 2003-07-09 2003 20 星期日

1 2003-07-10 2003 20 星期一

1 2003-07-11 2003 20 星期二

 

想要變成

--------------------

1 07/09/2003 2003 第20周(7/9-7/17)

1 07/10/2003 2003 第20周(7/9-7/17)

1 07/11/2003 2003 第20周(7/9-7/17)

請問:這個語句應該怎么去寫?


答: if object_id('tablename') is not null drop table tablename

select 1 as time_id, '2003-07-09' as time_date, 2003 as [year], 20 as week_of_year, '星期日' as [day]

into tablename

union select 1, '2003-07-10', 2003, 20, '星期一'

union select 1, '2003-07-11', 2003, 20, '星期二'

------------------------------------------------

select time_id, time_date, [year], '第' + cast(week_of_year as varchar(2)) + '周('

+ cast(month(week_begin) as varchar(2)) + '/' + cast(day(week_begin) as varchar(2)) + '-'

+ cast(month(week_end) as varchar(2)) + '/' + cast(day(week_end) as varchar(2)) as week_of_year

from (select *, dateadd(day, 1 - datepart(weekday, time_date), time_date) as week_begin,

dateadd(day, 7 - datepart(weekday, time_date), time_date) as week_end from tablename) a

/*

time_id time_date year week_of_year

1 2003-07-09 2003 第20周(7/6-7/12)

1 2003-07-10 2003 第20周(7/6-7/12)

1 2003-07-11 2003 第20周(7/6-7/12)

*/

------------------------------------------------

drop table tablename

 


問題雖然解決了,但這個例子并不具備通用性,還是個案,所以我們分析了你的代碼,發現一個問題:日期范圍是如何確定的?所以,我們把它延伸發散到:能否自主設定日期的范圍呢?比如設定到星期一或星期天開始:


思路:

SET DATEFIRST

將一周的第一天設置為從 1 到 7 之間的一個數字。


語法

SET DATEFIRST { number | @number_var }


參數

number | @number_var


是一個整數,表示一周的第一天,可以是下列值中的一個。


值 一周的第一天是

1 星期一

2 星期二

3 星期三

4 星期四

5 星期五

6 星期六

7(默認值,美國英語) 星期日

 

注釋

使用 @@DATEFIRST 函數檢查 SET DATEFIRST 的當前設置。


SET DATEFIRST 的設置是在執行或運行時設置,而不是在分析時設置。

 

方法一:

 

先創建一個用戶函數,根據日期得到周開始日期和結束日期

create function getwstend(@resultdate datetime)

returns varchar(20)

As

begin

declare @weekstart datetime,@weekend datetime,@dayweek int,@weeknum int

set @weeknum = datepart(wk,@resultdate)

set @dayweek = datepart(dw,@resultdate)

begin

set @weekstart = dateadd(dd,1-@dayweek,@resultdate)

set @weekend = DateAdd(dd,7-@dayweek,@resultdate)

end

return '第'+Convert(varchar,@weeknum)+'周'+'('+right(convert(varchar(10),@weekstart,111),5)+'--'+right(Convert(varchar(10),@weekend,111),5)+')'

end

Go

例如:

select test.getwstend('2006-4-17')

返回結果是:第16周(04/16--04/22)

利用這個函數相信就可以實現你的要求了,把所有表1中的數據轉到表2


方法二:


為了避免數據的冗余,建議不要把數據從第一個表轉到第二個表。因為這樣會造成數據冗余。你可以在查詢時候使用函數產生week_of_year nvarchar 這個欄位。


方法三:

 

創建一個表,欄位為:

create table tw

(

time_date datetime,

week_of_year nvarchar

)

然后1910.1.1---2050.12.31之間的所有日期都產生一個對照的week_of_year nvarchar,方法也是使用上面創建的函數。然后查詢的時候。只要兩個表作關聯就可以了

如果原始表中的記錄很多。而且日期有很多重復,我們更推薦使用方法三。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本精品一区二区三区在线播放视频| 国产视频久久久久| 亚洲一区二区三区乱码aⅴ蜜桃女| 91九色国产在线| 91sao在线观看国产| 久久中文字幕国产| 91久久综合亚洲鲁鲁五月天| 欧美激情高清视频| 欧美黑人狂野猛交老妇| 亚洲色图50p| 亚洲精品色婷婷福利天堂| 中文字幕精品久久| 欧美成年人视频网站欧美| 国产亚洲精品综合一区91| 欧美极品美女视频网站在线观看免费| 一区二区av在线| 久久影视电视剧免费网站| 日韩欧美国产高清91| 亚洲一区二区三区在线免费观看| 欧美韩国理论所午夜片917电影| 国产美女主播一区| 日本国产欧美一区二区三区| 日韩中文字幕国产精品| 国产精品大片wwwwww| 久久99视频免费| 亚洲欧美三级在线| 狠狠久久亚洲欧美专区| 国产一区二区三区在线观看视频| 国产成人精品视频在线| 久久av在线看| 国产精品久久久久久久9999| 亚洲第一精品久久忘忧草社区| 久久91亚洲精品中文字幕奶水| 亚洲欧美日本伦理| 国产精品电影一区| 久久91超碰青草是什么| 欧美老女人性生活| 日韩中文视频免费在线观看| 亚洲国产成人一区| 91精品久久久久久久久久另类| 日韩在线观看精品| 午夜精品www| 一区二区在线视频| 国产精品日日摸夜夜添夜夜av| 国产不卡一区二区在线播放| 亚洲人成电影网站色| 亚洲日本中文字幕免费在线不卡| 综合国产在线视频| 综合136福利视频在线| 久久久久久久一区二区三区| 91在线色戒在线| 国产精品扒开腿做爽爽爽的视频| 91国产视频在线| 欧美激情第三页| 日韩在线免费视频观看| 色综合色综合网色综合| 亚洲午夜女主播在线直播| 欧美精品成人91久久久久久久| 国产精品视频午夜| 久久夜色精品亚洲噜噜国产mv| 国产视频精品自拍| 亚洲福利小视频| 国产精品18久久久久久麻辣| 欧美激情在线观看| 91精品国产91久久久久| 欧美精品性视频| 在线观看欧美视频| 亚洲综合在线做性| 欧美日韩国产二区| 欧美极品少妇xxxxⅹ喷水| 日本三级韩国三级久久| 国产91色在线|| 欧美黑人视频一区| 国内精品伊人久久| 一区二区福利视频| 97精品一区二区三区| 一本色道久久综合狠狠躁篇的优点| 亚洲激情 国产| 麻豆国产精品va在线观看不卡| 日韩天堂在线视频| 97在线视频一区| 久久这里只有精品视频首页| 午夜精品一区二区三区在线视| 日韩电影中文字幕| 国产亚洲一区二区在线| 欧美理论片在线观看| 91精品国产99久久久久久| 亚洲图片在线综合| 国产91|九色| 视频在线一区二区| 日本精品va在线观看| 91九色国产社区在线观看| 国产精品福利无圣光在线一区| 亚洲人在线观看| 亚洲欧洲av一区二区| 91人成网站www| zzjj国产精品一区二区| 亚洲精品国偷自产在线99热| 伊人久久综合97精品| 在线一区二区日韩| 亚洲欧美日韩国产中文专区| 欧美精品激情在线观看| 6080yy精品一区二区三区| 日韩av影片在线观看| 高清一区二区三区日本久| 欧美极品少妇xxxxⅹ免费视频| 亚洲国产成人爱av在线播放| 国产欧美精品一区二区三区介绍| 2023亚洲男人天堂| 欧美大成色www永久网站婷| 日本19禁啪啪免费观看www| 国产一区二区三区在线播放免费观看| 欧美激情在线狂野欧美精品| 久久精品这里热有精品| 国内揄拍国内精品少妇国语| 精品五月天久久| 91极品女神在线| 97视频在线播放| 国产精品手机播放| 日韩激情视频在线| 国产+成+人+亚洲欧洲| 欧美黄色性视频| 亚洲成人中文字幕| 欧美精品免费在线观看| 精品小视频在线| 欧美日韩国产精品专区| 亚洲人成电影网站色www| 日韩av高清不卡| 亚洲一区999| 日韩免费在线观看视频| 69av在线视频| 亚洲精品www久久久| 国产一区二区av| 日韩精品极品在线观看| 91国产精品视频在线| 亚洲自拍在线观看| 国产精品中文字幕在线观看| 欧美在线视频免费播放| 国产精品中文在线| 精品视频在线播放色网色视频| 日韩天堂在线视频| 国产精品成人观看视频国产奇米| 亚洲3p在线观看| 一区二区三区回区在观看免费视频| 中文字幕亚洲一区二区三区五十路| 久久香蕉频线观| 色先锋资源久久综合5566| 亚洲综合在线中文字幕| 久久成人亚洲精品| 国产不卡视频在线| 欧美午夜片在线免费观看| 日本久久中文字幕| 日韩av在线高清| 久久97久久97精品免视看| 亚洲福利视频免费观看| 日韩欧美在线视频| 国产亚洲欧美日韩美女| 亚洲精品久久久久久久久久久久| 国产精品精品视频一区二区三区| 精品国产区一区二区三区在线观看| 性欧美在线看片a免费观看| 亚洲成人a级网| 欧美一级大片在线免费观看| 91精品在线国产|