成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

實現內容的時間交集計算的sql語句

數據庫 SQL Server
如果SQL數據庫中的記錄時間有交集,計算時又需要過濾掉,那么該SQL語句應該怎么寫呢?下面就為您介紹該SQL語句的詳細寫法,供您參考。

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  

 

 

 

 

【編輯推薦】

實現子孫樹查詢的經典SQL語句

查詢表的字段名的sql語句寫法

查詢表結構的SQL語句

使用SQL語句實現查詢連續號段

單表多條件查詢sql語句寫法

責任編輯:段燃 來源: 互聯網
相關推薦

2010-09-24 19:23:51

SQL查詢時間段

2010-09-06 13:17:19

SQL Server語句

2010-09-07 11:33:04

SQL語句

2010-09-26 17:09:05

SQL語句

2010-09-08 15:00:03

SQL語句執行

2010-11-15 14:16:09

Oracle表記錄

2010-10-21 14:27:35

SQL Server時

2023-03-30 09:10:06

SQLSELECTFROM

2010-09-03 15:47:40

SQL語句鎖定

2010-09-03 14:39:15

SQLSELECT語句

2017-05-16 11:20:51

SQL語句解析

2010-11-18 17:08:44

Oracle使用SQL

2010-11-09 15:30:01

Sql server時

2010-09-25 16:32:02

SQL語句

2010-09-17 16:03:17

鎖定SQL表

2010-11-11 11:37:22

SQL SELECT語

2010-09-08 16:26:26

SQL循環語句

2010-07-08 13:26:02

SQL Server

2010-09-28 09:42:25

sql語句

2010-09-03 14:47:50

SQLSELECT語句
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产做爰| 在线观看深夜视频 | 欧美日韩专区 | 日韩一区二区三区在线视频 | 在线国产一区 | 97人人超碰 | 国内精品久久精品 | a级毛片免费高清视频 | 在线综合视频 | 国产精品国色综合久久 | 日韩在线不卡视频 | a级黄色网| 99精品欧美一区二区蜜桃免费 | 久久国产精品一区二区三区 | 91视频久久| 日韩精品视频在线 | 精品国产1区2区3区 一区二区手机在线 | 丝袜一区二区三区 | 夜夜操天天操 | 欧美高清视频一区 | 皇色视频在线 | 黄色大片在线免费观看 | 精品福利av导航 | 欧美黄色免费网站 | 欧美日韩免费一区二区三区 | 日韩av一区二区在线观看 | 精品乱子伦一区二区三区 | 日本精品视频在线 | 欧美一级片在线播放 | 久久一起草 | 久久久91精品国产一区二区精品 | 日韩视频一区 | 国产精品视频一二三区 | 国产高清免费 | 中文字幕日韩一区 | 一级a性色生活片久久毛片波多野 | 亚洲综合色自拍一区 | 久草网址| 久久久久久久久久影视 | 日韩中文字幕久久 | 精品国产乱码久久久久久蜜柚 |