實(shí)現(xiàn)內(nèi)容的時(shí)間交集計(jì)算的sql語(yǔ)句
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ǔ)句代碼:
- --方便演示,定義一個(gè)Source的表變量,BeginTime是登錄時(shí)間,EndTime是離線時(shí)間
- declare @Source table(ID INT IDENTITY(1,1),BeginTime datetime, EndTime datetime)
- --定義輸出結(jié)果表變量
- declare @Result table(id INT IDENTITY(1,1),BeginTime datetime, EndTime DATETIME,OnlineTime INT NULL)
- --插入演示數(shù)據(jù)
- insert into @Source values('2010-08-16 08:00:00','2010-08-16 08:40:00')
- insert into @Source values('2010-08-16 09:00:00','2010-08-16 11:30:00')
- insert into @Source values('2010-08-16 09:01:00','2010-08-16 11:32:00')
- insert into @Source values('2010-08-16 10:01:00','2010-08-16 12:01:00')
- insert into @Source values('2010-08-16 11:00:00','2010-08-16 12:05:00')
- insert into @Source values('2010-08-16 12:10:00','2010-08-16 13:40:00')
- insert into @Source values('2010-08-16 13:10:00','2010-08-16 14:15:00')
- insert into @Source values('2010-08-16 14:00:00','2010-08-16 16:32:00')
- insert into @Source values('2010-08-16 07:20:00','2010-08-16 16:40:00')
- insert into @Source values('2010-08-16 17:00:00','2010-08-16 20:32:00')
- insert into @Source values('2010-08-16 07:00:00','2010-08-16 07:18:00')
- insert into @Source values('2010-08-16 07:30:00','2010-08-16 08:20:00')
- --模擬數(shù)據(jù)庫(kù)中的數(shù)據(jù),插入一些其他時(shí)間的數(shù)據(jù)
- insert into @Source values('2010-08-15 08:00:00','2010-08-16 08:40:00')
- insert into @Source values('2010-08-17 09:00:00','2010-08-16 11:30:00')
- insert into @Source values('2010-08-14 09:01:00','2010-08-16 11:32:00')
- insert into @Source values('2010-08-13 10:01:00','2010-08-16 12:01:00')
- insert into @Source values('2010-08-17 11:00:00','2010-08-16 12:05:00')
- insert into @Source values('2010-08-17 12:10:00','2010-08-16 13:40:00')
- insert into @Source values('2010-08-17 13:10:00','2010-08-16 14:15:00')
- insert into @Source values('2010-08-17 14:00:00','2010-08-16 16:32:00')
- insert into @Source values('2010-08-15 07:20:00','2010-08-16 16:40:00')
- insert into @Source values('2010-08-13 17:00:00','2010-08-16 20:32:00')
- insert into @Source values('2010-08-12 07:00:00','2010-08-16 07:18:00')
- insert into @Source values('2010-08-11 07:30:00','2010-08-16 08:20:00')
- --定義需要用到的變量
- DECLARE @count INT,@ID INT,@begintime DATETIME,@endtime DATETIME,@Date DATE
- --如果需要指定計(jì)算的日期,可以設(shè)置日期值,否則為null會(huì)計(jì)算全部的時(shí)間
- SET @Date = '2010-08-16 07:30:00'
- --如果日期不為空,則清除Source中的垃圾數(shù)據(jù)
- IF @Date IS NOT NULL
- BEGIN
- DELETE FROM @Source WHERE BeginTime < @Date OR BeginTime >= DATEADD(DAY,1,@Date)
- END
- --計(jì)算Count,以便進(jìn)行遍歷
- SELECT @count = COUNT(1) FROM @Source
- --遍歷Source中的數(shù)據(jù)
- WHILE @count > 0
- BEGIN
- --根據(jù)時(shí)間排序,每次取1條數(shù)據(jù)
- SELECT TOP 1 @begintime = BeginTime,@endtime = EndTime ,@IDID = ID FROM @Source
- ORDER BY BeginTime
- --如果Result中沒有記錄,則直接插入,否則進(jìn)行判斷
- IF NOT EXISTS(SELECT 1 FROM @Result)
- BEGIN
- insert into @Result values(@begintime,@endtime,NULL);
- END
- ELSE
- BEGIN
- --由于Source的數(shù)據(jù)是經(jīng)過(guò)排序的,所以下面的插入已經(jīng)無(wú)效,直接注釋掉
- --IF NOT EXISTS(SELECT 1 FROM @Result WHERE BeginTime < @endtime AND EndTime < @begintime)
- --BEGIN
- -- insert into @Result values(@begintime,@endtime,NULL);
- --END
- --如果開始時(shí)間大于Result中的已存在的記錄結(jié)束時(shí)間,則直接插入數(shù)據(jù)
- IF NOT EXISTS(SELECT 1 FROM @Result WHERE EndTime > @begintime)
- BEGIN
- insert into @Result values(@begintime,@endtime,NULL);
- END
- --判斷Result中的數(shù)據(jù)開始時(shí)間是否大于Source中的開始時(shí)間,大于則更新
- ELSE IF EXISTS(SELECT 1 FROM @Result WHERE BeginTime > @begintime AND EndTime < @endtime AND EndTime > @endtime)
- BEGIN
- UPDATE @Result SET BeginTime = @begintime WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime > @endtime
- END
- --判斷Result中的數(shù)據(jù)結(jié)束時(shí)間是否小于Source中的結(jié)束時(shí)間,小于則更新
- ELSE IF EXISTS(SELECT 1 FROM @Result WHERE BeginTime < @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime)
- BEGIN
- UPDATE @Result SET EndTime = @endtime WHERE BeginTime < @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime
- END
- --判斷Result中的記錄時(shí)間是否被Source中的時(shí)間被包含,包含則開始與結(jié)束都更新
- ELSE IF EXISTS(SELECT 1 FROM @Result WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime)
- BEGIN
- SELECT * FROM @Result WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime
- UPDATE @Result SET BeginTime = @begintime, EndTime = @endtime WHERE BeginTime > @begintime AND BeginTime < @endtime AND EndTime < @endtime AND EndTime > @begintime
- END
- END
- --刪除已經(jīng)讀取過(guò)的記錄
- DELETE FROM @Source WHERE id = @ID
- --更新Count
- SELECT @count = COUNT(1) FROM @Source
- END
- --計(jì)算OnlineTime
- UPDATE @Result SET OnlineTime = DATEDIFF(mi,BeginTime,EndTime)
- --顯示結(jié)果
- SELECT * FROM @Result
【編輯推薦】
實(shí)現(xiàn)子孫樹查詢的經(jīng)典SQL語(yǔ)句