问:请问专家,怎么样计算一个表中的周起始和截止日期并写到表字段中? 我要从一个表向另一个表导入数据,并进行转换,用的是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
|
如果您对本文有任何疑问或者建议,请到讨论区发表您的意见:
>>
论坛入口 <<
上一篇:
[Sql server]数据库人员:常见错误 下一篇:
[Sql server]某外企SQL Server面试题
【文章评论】
【收藏本文】
【推荐好友】
【打印本文】
【我要投稿】 【论坛讨论】