簡體   English   中英

用戶在同一天的30分鍾內執行的最大連續操作數

[英]max number of consecutive actions that the user performed within 30 minutes of the same day

我有用戶,動作和時間的表。我正在嘗試獲取用戶在當天30分鍾內執行的白天和最大連續動作的總動作。我是sql的新手,我發現了用戶的總動作但是如何在30分鍾內找到最大連續動作。我試過下面的查詢

我選擇e.user,COUNT(e.user)AS count FROM audit_log e GROUP BY e.user

SELECT  e.user, COUNT(e.user) AS count
FROM audit_log e
GROUP BY e.user

例如,假設用戶'userA'在以下時間戳期間執行了操作:

     time        action            user
* 08:05:10       edit                A
* 08:05:40       create              B
* 08:06:50       insert              A
* 08:30:20       ...                 .
* 08:31:50
* 08:35:10
* 10:00:50
* 12:34:32       call                A
* 12:43:23       delete              A
* 12:44:00       listen              A
* 12:45:52
* 12:45:59
* 12:46:59
* 13:04:33
* 16:30:21
* 18:04:47
* 18:05:02
* 20:20:20
* 23:39:21

今天將有一個條目如下:

| username | total action count | number of consecutive actions |
|  userA   |                 19 |                             6 |

這是sql數據

CREATE TABLE `audit_log` (
  `id` bigint(20) NOT NULL,
  `action_name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
  `user` varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL,
  `change_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

--
-- Dumping data for table `audit_log`
--

INSERT INTO `audit_log` (`id`, `action_name`, `user`, `change_time`) VALUES
(1, 'deploy', 'Cristina Fitzgerald', '2018-05-15 06:38:00'),
(2, 'delete', 'Kobie Tillman', '2018-05-15 06:53:00'),
(3, 'modify', 'Willa Sharpe', '2018-05-15 07:08:00'),
(4, 'delete', 'Aimee Walter', '2018-05-15 07:14:00'),
(5, 'delete', 'Willa Sharpe', '2018-05-15 07:28:00'),
(6, 'modify', 'Cristina Fitzgerald', '2018-05-15 07:38:00'),
(7, 'deploy', 'Willa Sharpe', '2018-05-15 08:28:00'),
(8, 'modify', 'Aimee Walter', '2018-05-15 09:14:00'),
(9, 'deploy', 'Kobie Tillman', '2018-05-15 09:53:00'),
(10, 'delete', 'Aimee Walter', '2018-05-15 10:09:00'),
(11, 'modify', 'Aimee Walter', '2018-05-15 10:29:00'),
(12, 'modify', 'Cristina Fitzgerald', '2018-05-15 10:38:00'),
(13, 'delete', 'Cristina Fitzgerald', '2018-05-15 11:06:00'),
(14, 'create', 'Aimee Walter', '2018-05-15 11:23:00'),
(15, 'create', 'Cristina Fitzgerald', '2018-05-15 11:44:00'),
(16, 'deploy', 'Aimee Walter', '2018-05-15 11:45:00'),
(17, 'create', 'Aimee Walter', '2018-05-15 11:58:00'),
(18, 'delete', 'Cristina Fitzgerald', '2018-05-15 12:19:00'),
(19, 'delete', 'Cristina Fitzgerald', '2018-05-15 12:23:00'),
(20, 'modify', 'Aimee Walter', '2018-05-15 12:31:00'),
(21, 'delete', 'Cristina Fitzgerald', '2018-05-15 13:14:00'),
(22, 'deploy', 'Aimee Walter', '2018-05-15 13:21:00'),
(23, 'create', 'Aimee Walter', '2018-05-15 13:24:00'),
(24, 'deploy', 'Willa Sharpe', '2018-05-15 13:28:00'),
(25, 'modify', 'Kobie Tillman', '2018-05-15 13:53:00'),
(26, 'delete', 'Kobie Tillman', '2018-05-15 14:23:00'),
(27, 'delete', 'Kobie Tillman', '2018-05-15 14:30:00'),
(28, 'create', 'Kobie Tillman', '2018-05-15 14:39:00'),
(29, 'deploy', 'Kobie Tillman', '2018-05-15 15:13:00'),
(30, 'modify', 'Willa Sharpe', '2018-05-15 15:17:00'),
(31, 'modify', 'Willa Sharpe', '2018-05-15 15:27:00'),
(32, 'create', 'Kobie Tillman', '2018-05-15 15:32:00'),
(33, 'modify', 'Kobie Tillman', '2018-05-15 15:53:00'),
(34, 'deploy', 'Kobie Tillman', '2018-05-15 16:00:00'),
(35, 'delete', 'Kobie Tillman', '2018-05-15 16:59:00'),
(36, 'deploy', 'Kobie Tillman', '2018-05-15 18:59:00'),
(37, 'modify', 'Aimee Walter', '2018-05-15 19:24:00'),
(38, 'delete', 'Willa Sharpe', '2018-05-15 19:27:00'),
(39, 'modify', 'Kobie Tillman', '2018-05-15 19:34:00'),
(40, 'delete', 'Aimee Walter', '2018-05-15 20:02:00'),
(41, 'delete', 'Willa Sharpe', '2018-05-15 20:09:00'),
(42, 'deploy', 'Aimee Walter', '2018-05-15 20:18:00'),
(43, 'delete', 'Willa Sharpe', '2018-05-15 20:40:00'),
(44, 'modify', 'Willa Sharpe', '2018-05-15 20:59:00'),
(45, 'create', 'Cristina Fitzgerald', '2018-05-15 21:14:00'),
(46, 'deploy', 'Kobie Tillman', '2018-05-15 21:34:00'),
(47, 'modify', 'Kobie Tillman', '2018-05-15 21:40:00'),
(48, 'create', 'Willa Sharpe', '2018-05-15 21:59:00'),
(49, 'delete', 'Willa Sharpe', '2018-05-15 22:51:00'),
(50, 'create', 'Willa Sharpe', '2018-05-15 23:12:00');

更新一個

  • 這個新查詢減少了連接數,
  • 使用一種新方法進行范圍計數和簡單連接來進行計算。
  • 可以在此處使用userchange_time字段的索引來加快速度。

注意:要選擇特定時間的記錄,請在change_time字段的兩個表上使用WHERE條件。

SELECT 
    `user`,
    COUNT(0) as Total_Count,
    MAX(range_count) Max_Range_Count
FROM (
    SELECT
        a.`user`, 
        a.change_time, 
        COUNT(0) range_count
    FROM audit_log a
    INNER JOIN audit_log b ON a.`user` = b.`user` 
    WHERE b.change_time BETWEEN a.change_time AND a.change_time + INTERVAL 30 MINUTE
    GROUP BY a.`user`, a.change_time
) AS user_range_count
GROUP BY `user`;

舊查詢

目前,如果我們不將性能視為一個因素。 這是為您提供所需結果的查詢。

  • 首先,創建所有30分鍾范圍,這些范圍可以由用戶進行最大連續操作。

  • 其次,獲得每用戶和每30分鍾范圍的計數。

  • 第三,直接從表中獲取總計數,並從上一步獲得最大(30分鍾)范圍計數。

SELECT audit_log.user, COUNT(DISTINCT id), MAX(b.time_range_count)
FROM audit_log 
INNER JOIN (    
    SELECT audit_log.user, a.time_range, COUNT(0) as time_range_count
    FROM audit_log
    INNER JOIN (
        SELECT 
            CONCAT_WS(' - ',change_time, change_time + INTERVAL 30 MINUTE) AS time_range, 
            change_time, 
            change_time + INTERVAL 30 MINUTE change_time_30
        FROM audit_log
        ORDER BY change_time
    ) AS a ON audit_log.change_time BETWEEN a.change_time AND a.change_time_30
    GROUP BY audit_log.user, a.time_range
) AS b ON audit_log.user = b.user
GROUP BY audit_log.user;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM