2016-11-11 46 views
0

这是包含日志我的表:MySQL的排序分组的记录

message     | data 
---------------------------------------------- 
ttt,tu10=UP,tu20=UP  | 2016-11-11 10:15:05 
ttt,tu10=DOWN,tu20=DOWN | 2016-11-11 10:13:05 
ttt,oper=UP,oper2=UP  | 2016-11-11 10:13:01 
ttt,oper=DOWN,oper2=DOWN | 2016-11-11 10:07:05 
hhh,tu10=UP,tu20=UP  | 2016-11-11 10:05:04 
hhh,tu10=DOWN,tu20=DOWN | 2016-11-11 10:05:01 
hhh,tu10=DOWN,tu20=DOWN | 2016-11-11 09:43:01 
hhh,tu10=UP,tu20=UP  | 2016-11-11 09:37:04 
hhh,tu10=DOWN,tu20=DOWN | 2016-11-11 09:35:05 
ttt,tu10=DOWN,tu20=DOWN | 2016-11-11 09:35:01 
ttt,tu10=UP,tu20=UP  | 2016-11-11 09:33:05 
ttt,tu10=DOWN,tu20=DOWN | 2016-11-11 05:35:01 
hhh,tu10=UP,tu20=UP  | 2016-11-11 05:33:05 

我创造了这个查询:在屏幕上

SELECT * 
    FROM (
     SELECT 
      *,COUNT(*) AS count 
     FROM log 
     WHERE data > DATE_SUB(NOW(), INTERVAL 2 HOUR) 
     GROUP BY substring_index(message,',',1) 
    ) AS tmp 
WHERE count > 3 

打印: '信息', '数据', '计数'

获取类似:

ttt,tu10=UP,tu20=UP  | 2016-11-11 09:33:05 | 6 
hhh,tu10=DOWN,tu20=DOWN | 2016-11-11 09:35:05 | 5 

而且我想得到第一个,像这样:

ttt,tu10=UP,tu20=UP | 2016-11-11 10:15:05 | 6 
hhh,tu10=UP,tu20=UP | 2016-11-11 10:05:04 | 5 

我已经尝试了几种方法来排序,但我放弃了。

+0

ü没有提到你想在你的问题是什么?除了你预期的结果,请说你想要什么关于这个结果。 – Zeina

+0

“GROUP BY substring_index(message,',',1)”这类问题是设计不佳的表现。 – Strawberry

+0

我想显示一条消息,日期和出现次数,但是我想查看最新的消息和日期。 –

回答

0

我会建议使用substring_index()/group_concat()伎俩为了这个目的:

SELECT SUBSTRING_INDEX(GROUP_CONCAT(message ORDER BY data DESC SEPARATOR '|'), '|', 1) as message, 
     MAX(data) as data, COUNT(*) AS count 
FROM log l 
WHERE data > DATE_SUB(NOW(), INTERVAL 2 HOUR) 
GROUP BY substring_index(message, ',', 1) 
HAVING COUNT(*) >= 3; 

请注意,GROUP_CONCAT()有一个内部限制由系统变量设置,与1024的默认值。如果消息超过这个长度,它将产生一个错误。您可以重置长度。

另一种方法是:

select l.* 
from (select substring_index(message, ',', 1) as m1, max(data) as maxd 
     from log 
     group by substring_index(message, ',', 1) 
     having count(*) >= 3 
    ) ll join 
    l 
    on ll.m1 = substring_index(l.message, ',', 1) and ll.maxd = l.data