start_dt id project
2011-12-02 23:30:00 1 NM1
2011-12-05 22:30:00 2 NM2
2011-12-02 14:45:00 3 NM1如何根据以上的条件,查询每个project的用时。
如project NM2用时等于 2011-12-05 22:30:00 减去 2011-12-02 23:30:00
project NM1用时等于 2011-12-02 23:30:00 减去 2011-12-02 07:00:00(查询开始时间)。结果是use_dt project
?? NM2
?? NM1请大侠们帮帮忙
感激不尽!!
2011-12-02 23:30:00 1 NM1
2011-12-05 22:30:00 2 NM2
2011-12-02 14:45:00 3 NM1如何根据以上的条件,查询每个project的用时。
如project NM2用时等于 2011-12-05 22:30:00 减去 2011-12-02 23:30:00
project NM1用时等于 2011-12-02 23:30:00 减去 2011-12-02 07:00:00(查询开始时间)。结果是use_dt project
?? NM2
?? NM1请大侠们帮帮忙
感激不尽!!
解决方案 »
- 急:动态获取SQLserver2008数据库名称并且根据数据库名称获得当前库的表中数据集.
- 新手问题:如何把sql server的数据(或者查询结果)导出到excel中,是否有第三方工具
- 根据条件生成新列、sql2000环境
- 关于数据同步问题(报错信息看不明白)高手请进+++++++急急急
- 菜鸟求助
- 如何在查询时两条纪录合成一条,不同的地方自动生成新的字段?
- 两张有关联的表进行合并
- 求下列数据库的ODBC驱动程序,版本不限,越多越好,只要提供有效连接地址既可。
- 对于在SQL Server中写的函数及存储过程,如何才能让使用者只能调用而不能阅读源代码?用户拥有管理员权限的。是否存储过程编译后就只能调
- 如何删除两张相关联的表中的记录,急~~~~~~~~不做好不能回家了55555
- 如何导入大型.SQL文件到MY SQL中
- 求SQL语句
insert into tb values('2011-12-02 23:30:00', 1 ,'NM1')
insert into tb values('2011-12-05 22:30:00', 2 ,'NM2')
insert into tb values('2011-12-02 14:45:00', 3 ,'NM1')
goselect t.* , [用时(s)] = abs(datediff(ss,isnull((select top 1 start_dt from tb where id < t.id order by id) , '2011-12-02 07:00:00'),t.start_dt)) from tb tdrop table tb/*
start_dt id project 用时(s)
------------------------------------------------------ ----------- ---------- -----------
2011-12-02 23:30:00.000 1 NM1 59400
2011-12-05 22:30:00.000 2 NM2 255600
2011-12-02 14:45:00.000 3 NM1 31500(所影响的行数为 3 行)*/
insert into tb values('2011-12-02 23:30:00', 1 ,'NM1')
insert into tb values('2011-12-05 22:30:00', 2 ,'NM2')
insert into tb values('2011-12-02 14:45:00', 3 ,'NM1')
goselect t.* , [用时(s)] = abs(datediff(ss,isnull((select top 1 start_dt from tb where id < t.id order by id) , '2011-12-02 07:00:00'),t.start_dt)) from tb t
/*
start_dt id project 用时(s)
------------------------------------------------------ ----------- ---------- -----------
2011-12-02 23:30:00.000 1 NM1 59400
2011-12-05 22:30:00.000 2 NM2 255600
2011-12-02 14:45:00.000 3 NM1 31500(所影响的行数为 3 行)*/select project , sum([用时(s)]) [用时(s)] from
(
select t.* , [用时(s)] = abs(datediff(ss,isnull((select top 1 start_dt from tb where id < t.id order by id) , '2011-12-02 07:00:00'),t.start_dt)) from tb t
) m
group by project
/*
project 用时(s)
---------- -----------
NM1 90900
NM2 255600(所影响的行数为 2 行)
*/drop table tb
go
create table [TB] (start_dt datetime,id int,project nvarchar(6))
insert into [TB]
select '2011-12-02 23:30:00',1,'NM1' union all
select '2011-12-05 22:30:00',2,'NM2' union all
select '2011-12-02 14:45:00',3,'NM1'select * from [TB]
SELECT B.project,ABS(DATEDIFF(ss,B.start_dt,A.start_dt)) AS 用时
FROM TB A
INNER JOIN TB B ON A.id = B.id - 1/*
project 用时
NM2 255600
NM1 287100*/
b.project,abs(datediff(ss,b.start_dt,a.start_dt))
from
a,b
where
a.id=b.id-1