給定一個表具有以下字段之間的事件「會話」:MySQL的:創建兩個日期
username | event | time (hh:mm:ss)
user2 | login | 03:27:17
user2 | check messages | 03:31:31
user2 | view profile | 03:32:01
user2 | logout | 03:32:48
user3 | login | 13:00:59
user3 | change billing info | 13:03:11
user3 | logout | 13:03:32
我試圖創建用戶「會話」,使用首次作爲「登錄」時間和最後一次作爲「註銷」時間。結果表應該是:
username | event | login time | event time | logout time
user2 | login | 03:27:17 | 03:27:17 | 03:32:48
user2 | check messages | 03:27:17 | 03:31:31 | 03:32:48
user2 | view profile | 03:27:17 | 03:32:01 | 03:32:48
user2 | logout | 03:27:17 | 03:32:48 | 03:32:48
user3 | login | 13:00:59 | 13:00:39 | 13:03:32
user3 | change billing info | 13:00:59 | 13:03:11 | 13:03:32
user3 | logout | 13:00:59 | 13:03:32 | 13:03:32
我曾嘗試使用分鐘(時間)和最大值(時間)來獲得登錄和退出時間,但是當我這樣做,我得到的登錄,事件和註銷倍混合。
SELECT login.eventTime, actualEvent.eventTime, logout.eventTime
FROM tableName login, tableName actualEvent, tableName logout
WHERE login.username = actualEvent.username
AND actualEvent.username = logout.username
AND login.eventTime =
(SELECT MIN(minTime.eventTime)
FROM tableName minTime
WHERE minTime.username = login.username)
AND logout.eventTime =
(SELECT MAX(maxTime.eventTime)
FROM tableName maxTime
WHERE maxTime.username = login.username)
AND login.eventTime < logout.eventTime;
任何幫助將不勝感激。
編輯: @Bernd Buffen的回答很好,除非時間發生在多個日期。例如:
username | event | time (hh:mm:ss)
user2 | login | 08/11/2015 03:27:17
user2 | check messages | 08/11/2015 03:31:31
user2 | view profile | 08/11/2015 03:32:01
user2 | logout | 08/11/2015 03:32:48
user3 | login | 08/11/2015 13:00:59
user3 | change billing info | 08/11/2015 13:03:11
user3 | logout | 08/11/2015 13:03:32
user2 | login | 08/12/2015 04:00:00
user2 | change billing info | 08/12/2015 04:03:22
user2 | logout | 08/12/2015 04:08:17
在此事件中,我的輸出表的會話結束時間提前了幾天。有關如何解決此問題的任何建議?
粘貼您使用當前的SQL命令,所以我們可以來看看。 – jpaljasma
爲什麼查看消息和查看配置文件是在實際登錄時間? – Tarek