当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2011-01-25 23:11:00  来源:本站整理

<b>实现内容的时间交集计算的sql语句</b>[MSSQL防范]

赞助商链接



  本文“<b>实现内容的时间交集计算的sql语句</b>[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

sql语句可以实现大量我们需求的功效,下面介绍的sql语句可以实现内容的时间交集计算,但愿对您有所启迪.

假如在系统中有一张IM的登录记录表,里面是员工IM的登录时间,有登录时间,离线时间,最后活动时间.

因为员工上半时有大概会同时登录多个IM,此中的时间会有交集,因为要计算员工每天IM在线的工作时间,交集时间需求过滤掉.

直接在sql server中便可以对比便利的计算出相关内容.具体的直接上sql语句代码:

  1. --便利演示,定义一个Source的表变量,BeginTime是登录时间,EndTime是离线时间  
  2. declare @Source table(ID INT IDENTITY(1,1),BeginTime datetime, EndTime datetime)  
  3. --定义输出后果表变量  
  4. declare @Result table(id INT IDENTITY(1,1),BeginTime datetime, EndTime DATETIME,OnlineTime INT NULL)  
  5.  
  6. --插入演示数据  
  7. insert into @Source values('2010-08-16 08:00:00','2010-08-16 08:40:00')  
  8. insert into @Source values('2010-08-16 09:00:00','2010-08-16 11:30:00')  
  9. insert into @Source values('2010-08-16 09:01:00','2010-08-16 11:32:00')  
  10. insert into @Source values('2010-08-16 10:01:00','2010-08-16 12:01:00')  
  11. insert into @Source values('2010-08-16 11:00:00','2010-08-16 12:05:00')  
  12. insert into @Source values('2010-08-16 12:10:00','2010-08-16 13:40:00')  
  13. insert into @Source values('2010-08-16 13:10:00','2010-08-16 14:15:00')  
  14. insert into @Source values('2010-08-16 14:00:00','2010-08-16 16:32:00')  
  15. insert into @Source values('2010-08-16 07:20:00','2010-08-16 16:40:00')  
  16. insert into @Source values('2010-08-16 17:00:00','2010-08-16 20:32:00')  
  17. insert into @Source values('2010-08-16 07:00:00','2010-08-16 07:18:00')  
  18. insert into @Source values('2010-08-16 07:30:00','2010-08-16 08:20:00')  
  19.  
  20. --模拟数据库中的数据,插入一些其他时间的数据  
  21. insert into @Source values('2010-08-15 08:00:00','2010-08-16 08:40:00')  
  22. insert into @Source values('2010-08-17 09:00:00','2010-08-16 11:30:00')  
  23. insert into @Source values('2010-08-14 09:01:00','2010-08-16 11:32:00')  
  24. insert into @Source values('2010-08-13 10:01:00','2010-08-16 12:01:00')  
  25. insert into @Source values('2010-08-17 11:00:00','2010-08-16 12:05:00')  
  26. insert into @Source values('2010-08-17 12:10:00','2010-08-16 13:40:00')  
  27. insert into @Source values('2010-08-17 13:10:00','2010-08-16 14:15:00')  
  28. insert into @Source values('2010-08-17 14:00:00','2010-08-16 16:32:00')  
  29. insert into @Source values('2010-08-15 07:20:00','2010-08-16 16:40:00')  
  30. insert into @Source values('2010-08-13 17:00:00','2010-08-16 20:32:00')  
  31. insert into @Source values('2010-08-12 07:00:00','2010-08-16 07:18:00')  
  32. insert into @Source values('2010-08-11 07:30:00','2010-08-16 08:20:00')  
  33.  
  34. --定义需求用到的变量  
  35. DECLARE @count INT,@ID INT,@begintime DATETIME,@endtime DATETIME,@Date DATE  
  36.  
  37. --假如需求指定计算的日期,可以设置日期值,不然为null会计算全部的时间  
  38. SET @Date = '2010-08-16 07:30:00' 
  39.  
  40. --假如日期不为空,则排除Source中的垃圾数据  
  41. IF @Date IS NOT NULL  
  42. BEGIN  
  43.     DELETE FROM @Source WHERE BeginTime < @Date OR BeginTime >= DATEADD(DAY,1,@Date)  
  44. END  
  45.  
  46. --计算Count,以便举行遍历  
  47. SELECT @count = COUNT(1) FROM @Source  
  48.  
  49. --遍历Source中的数据  
  50. WHILE @count > 0  
  51. BEGIN  
  52.       
  53.     --按照时间排序,每次取1条数据  
  54.     SELECT TOP 1 @begintime = BeginTime,@endtime = EndTime ,@IDID = ID FROM @Source  
  55.     ORDER BY BeginTime  
  56.       
  57.     --假如Result中没有记录,则直接插入,不然举行判断  
  58.     IF NOT EXISTS(SELECT 1 FROM @Result)  
  59.     BEGIN  
  60.         insert into @Result values(@begintime,@endtime,NULL);  
  61.     END  
  62.     ELSE  
  63.     BEGIN  
  64.         --由于Source的数据是经过排序的,所以下面的插入已经无效,直接注释掉  
  65.         --IF NOT EXISTS(SELECT 1 FROM @Result WHERE BeginTime < @endtime AND EndTime < @begintime)  
  66.         --BEGIN  
  67.         --    insert into @Result values(@begintime,@endtime,NULL);  
  68.         --END  
  69.           
  70.         --假如开始时间大于Result中的已存在的记录完毕时间,则直接插入数据  
  71.         IF NOT EXISTS(SELECT 1 FROM @Result WHERE EndTime > @begintime)  
  72.         BEGIN  
  73.             insert into @Result values(@begintime,@endtime,NULL);  
  74.         END  
  75.         --判断Result中的数据开始时间能否大于Source中的开始时间,大于则更新  
  76.         ELSE IF EXISTS(SELECT 1 FROM @Result WHERE BeginTime > @begintime AND EndTime < @endtime AND EndTime > @endtime)  
  77.         BEGIN  
  78.             UPDATE @Result SET BeginTime = @begintime WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime > @endtime  
  79.         END  
  80.         --判断Result中的数据完毕时间能否小于Source中的完毕时间,小于则更新  
  81.         ELSE IF EXISTS(SELECT 1 FROM @Result WHERE BeginTime < @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime)  
  82.         BEGIN  
  83.             UPDATE @Result SET EndTime = @endtime WHERE BeginTime < @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime  
  84.         END  
  85.         --判断Result中的记录时间能否被Source中的时间被包含,包含则开始与完毕都更新  
  86.         ELSE IF EXISTS(SELECT 1 FROM @Result WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime)  
  87.         BEGIN  
  88.             SELECT * FROM @Result WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime  
  89.             UPDATE @Result SET BeginTime = @begintime, EndTime = @endtime WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime  
  90.         END  
  91.     END  
  92.       
  93.     --删除已经读取过的记录  
  94.     DELETE FROM @Source WHERE id = @ID  
  95.     --更新Count  
  96.     SELECT @count = COUNT(1) FROM @Source  
  97. END  
  98.  
  99. --计算OnlineTime  
  100. UPDATE @Result SET OnlineTime = DATEDIFF(mi,BeginTime,EndTime)  
  101. --显示后果  
  102. SELECT * FROM @Result  
<
  以上是“<b>实现内容的时间交集计算的sql语句</b>[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .