自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

實(shí)現(xiàn)內(nèi)容的時(shí)間交集計(jì)算的sql語(yǔ)句

數(shù)據(jù)庫(kù) SQL Server
如果SQL數(shù)據(jù)庫(kù)中的記錄時(shí)間有交集,計(jì)算時(shí)又需要過(guò)濾掉,那么該SQL語(yǔ)句應(yīng)該怎么寫呢?下面就為您介紹該SQL語(yǔ)句的詳細(xì)寫法,供您參考。

sql語(yǔ)句可以實(shí)現(xiàn)大量我們需要的功能,下面介紹的sql語(yǔ)句可以實(shí)現(xiàn)內(nèi)容的時(shí)間交集計(jì)算,希望對(duì)您有所啟迪。

如果在系統(tǒng)中有一張IM的登錄記錄表,里面是員工IM的登錄時(shí)間,有登錄時(shí)間,離線時(shí)間,***活動(dòng)時(shí)間。

因?yàn)閱T工上半時(shí)有可能會(huì)同時(shí)登錄多個(gè)IM,其中的時(shí)間會(huì)有交集,因?yàn)橐?jì)算員工每天IM在線的工作時(shí)間,交集時(shí)間需要過(guò)濾掉。

直接在sql server中就可以比較方便的計(jì)算出相關(guān)內(nèi)容。具體的直接上sql語(yǔ)句代碼:

  1. --方便演示,定義一個(gè)Source的表變量,BeginTime是登錄時(shí)間,EndTime是離線時(shí)間  
  2. declare @Source table(ID INT IDENTITY(1,1),BeginTime datetime, EndTime datetime)  
  3. --定義輸出結(jié)果表變量  
  4. declare @Result table(id INT IDENTITY(1,1),BeginTime datetime, EndTime DATETIME,OnlineTime INT NULL)  
  5.  
  6. --插入演示數(shù)據(jù)  
  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. --模擬數(shù)據(jù)庫(kù)中的數(shù)據(jù),插入一些其他時(shí)間的數(shù)據(jù)  
  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. --如果需要指定計(jì)算的日期,可以設(shè)置日期值,否則為null會(huì)計(jì)算全部的時(shí)間  
  38. SET @Date = '2010-08-16 07:30:00' 
  39.  
  40. --如果日期不為空,則清除Source中的垃圾數(shù)據(jù)  
  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. --計(jì)算Count,以便進(jìn)行遍歷  
  47. SELECT @count = COUNT(1) FROM @Source  
  48.  
  49. --遍歷Source中的數(shù)據(jù)  
  50. WHILE @count > 0  
  51. BEGIN  
  52.       
  53.     --根據(jù)時(shí)間排序,每次取1條數(shù)據(jù)  
  54.     SELECT TOP 1 @begintime = BeginTime,@endtime = EndTime ,@IDID = ID FROM @Source  
  55.     ORDER BY BeginTime  
  56.       
  57.     --如果Result中沒有記錄,則直接插入,否則進(jìn)行判斷  
  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的數(shù)據(jù)是經(jīng)過(guò)排序的,所以下面的插入已經(jīng)無(wú)效,直接注釋掉  
  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.         --如果開始時(shí)間大于Result中的已存在的記錄結(jié)束時(shí)間,則直接插入數(shù)據(jù)  
  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中的數(shù)據(jù)開始時(shí)間是否大于Source中的開始時(shí)間,大于則更新  
  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中的數(shù)據(jù)結(jié)束時(shí)間是否小于Source中的結(jié)束時(shí)間,小于則更新  
  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中的記錄時(shí)間是否被Source中的時(shí)間被包含,包含則開始與結(jié)束都更新  
  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.     --刪除已經(jīng)讀取過(guò)的記錄  
  94.     DELETE FROM @Source WHERE id = @ID  
  95.     --更新Count  
  96.     SELECT @count = COUNT(1) FROM @Source  
  97. END  
  98.  
  99. --計(jì)算OnlineTime  
  100. UPDATE @Result SET OnlineTime = DATEDIFF(mi,BeginTime,EndTime)  
  101. --顯示結(jié)果  
  102. SELECT * FROM @Result  

 

 

 

 

【編輯推薦】

實(shí)現(xiàn)子孫樹查詢的經(jīng)典SQL語(yǔ)句

查詢表的字段名的sql語(yǔ)句寫法

查詢表結(jié)構(gòu)的SQL語(yǔ)句

使用SQL語(yǔ)句實(shí)現(xiàn)查詢連續(xù)號(hào)段

單表多條件查詢sql語(yǔ)句寫法

責(zé)任編輯:段燃 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-09-24 19:23:51

SQL查詢時(shí)間段

2010-09-06 13:17:19

SQL Server語(yǔ)句

2010-09-08 15:00:03

SQL語(yǔ)句執(zhí)行

2010-09-07 11:33:04

SQL語(yǔ)句

2010-11-15 14:16:09

Oracle表記錄

2010-09-26 17:09:05

SQL語(yǔ)句

2010-10-21 14:27:35

SQL Server時(shí)

2010-09-03 14:39:15

SQLSELECT語(yǔ)句

2010-09-03 15:47:40

SQL語(yǔ)句鎖定

2023-03-30 09:10:06

SQLSELECTFROM

2010-11-09 15:30:01

Sql server時(shí)

2010-09-25 16:32:02

SQL語(yǔ)句

2010-09-28 09:42:25

sql語(yǔ)句

2010-07-08 13:26:02

SQL Server

2010-09-17 16:03:17

鎖定SQL表

2010-09-08 16:26:26

SQL循環(huán)語(yǔ)句

2010-11-11 11:37:22

SQL SELECT語(yǔ)

2010-11-18 17:08:44

Oracle使用SQL

2017-05-16 11:20:51

SQL語(yǔ)句解析

2010-09-03 11:25:58

SQL刪除
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)