posts - 2,comments - 0,trackbacks - 0

如login表有人员ID登陆或登出时间time求每天每次登陆登出一次的在线时间:
 

select login.id as人员ID ,login.status as 登陆登出状态
 login.time as 登陆或登出时间 ,
lead(login.time) over (partition by login.id,trunc(login.time) order by login.time)  as 下次登出或登出时间

from login login

这样状态是登陆的记录就会同时拥有登出的时间,这样两者一减就是在线时间了。
lead函数是取下一条记录,over (partition by login.id,trunc(login.time))如同对id,time分组,
order by login.time是按时间排序,这样可以知道是登陆登出的顺寻
posted @ 2010-01-30 16:18 胡章俊 阅读(799) | 评论 (0)编辑 收藏
新人报到
posted @ 2009-08-14 11:46 胡章俊 阅读(111) | 评论 (0)编辑 收藏
仅列出标题