Chinaunix首页 | 论坛 | 博客
  • 博客访问: 95845
  • 博文数量: 39
  • 博客积分: 2510
  • 博客等级: 少校
  • 技术积分: 405
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-25 09:25
文章分类

全部博文(39)

文章存档

2011年(1)

2010年(5)

2009年(4)

2008年(29)

我的朋友
最近访客

分类:

2010-10-12 12:26:34

USE T_SQL;
GO
CREATE FUNCTION dbo.get_avg_time
 (@b_time datetime,@e_time datetime,@clerk varchar(50))
RETURNS @avg_time table
(
  clerk varchar(50),
  avg_time varchar(8)
)
AS
  BEGIN
   insert into @avg_time
   select clerk,convert(varchar(8),dateadd(ss,time,108),108)
   from
   (select clerk,
   avg(substring(convert(varchar(19),d_t,120), 12, 2) * 3600 +
      substring(convert(varchar(19),d_t,120), 15, 2) * 60 +
      substring(convert(varchar(19),d_t,120), 18, 2))
   as time
   from login_log
    where d_t between @b_time and @e_time
    and clerk = @clerk
    group by clerk )as tt
    return
END
GO

测试:
 

    insert into login_log
    values ('一哥','2010-10-02 08:20:00');
        insert into #tt
    values ('一哥','2010-10-03 08:10:00');
    insert into #tt
    values ('一哥','2010-10-04 08:30:00');
    insert into #tt
    values ('吴哥','2010-10-04 08:10:00');
        insert into #tt
    values ('吴哥','2010-10-05 08:20:00');
    insert into #tt
    values ('吴哥','2010-10-06 08:15:00');

    select * from dbo.get_avg_time('2010-10-02 08:20:00',getdate(),'吴哥')


阅读(449) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~