Linux中国 Linux中国门户站!
设为主页 设为主页
收藏本站 收藏本站
 
当前位置 :首页 ->数据库应用 ->SQL Server ->正文

[Sql server]SQL中的时间计算语句

来源:IT 专家网  作者:Webmaster 时间:2007-04-23 点击: [收藏] [投稿]

问:请问专家,怎么样计算一个表中的周起始和截止日期并写到表字段中? 我要从一个表向另一个表导入数据,并进行转换,用的是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面试题

文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【我要投稿】 【论坛讨论
更多相关文章
Power by linux-cn.com 粤ICP备05006655号