如何比较列名称对的两个最新记录

时间:2012-11-27 00:00:12

标签: php mysql compare

我正在使用PHP和MySQL,并具有以下表结构:

        date             |      name      |       value

2012-11-20 10:30:03            visits              503
2012-10-23 09:30:03           pageviews            567
2012-09-23 09:30:03           pageviews            345
2012-10-20 11:30:03            visits              874

我需要运行一个MySQL查询,比较每个名称/值对的两个最新记录,如果名称/值对的值已经下降或上升,则返回。

例如,使用上面的示例数据,当访问次数减少时,查询会返回网页浏览量上升。

1 个答案:

答案 0 :(得分:1)

如果您想在MySQL中完全进行比较,可以分两步完成。

请在此处查看SQLFiddle - http://sqlfiddle.com/#!2/80677/9/0。注意 - SQLFIDDLE不允许CREATE TEMPORARY TABLE,因此我必须将其修改为CREATE TABLE

首先,您需要创建一个临时表,该表仅包含每个name组的最后两行 -

CREATE TEMPORARY TABLE tmptable
   SELECT * FROM
        (SELECT IF(@prev != sq.name, @rownum:=1, @rownum:=@rownum + 1) AS rownumber, @prev:=sq.name, sq.* FROM
       (SELECT * FROM table_name , (SELECT @rownum:=0, @prev:=0) r ORDER BY name, date DESC ) sq
   ) q WHERE q.rownumber <=2;

然后,您将比较这两行中的每一行,以确定它是上升还是下降 -

SELECT a.name,
       IF(a.value > b.value, 'up', 'down') action
FROM tmptable a
JOIN tmptable b 
ON a.name = b.name AND a.date > b.date ORDER BY a.date DESC;

如果您的表格结构与您发布的表格结构相同 - (date,name,value) - 则您需要进行的唯一更改是在table_name查询中显示CREATE TEMPORARY TABLE

在PHP中,您可以回显 -

while($row = ...fetch_array($query)){
  echo $row['name'] ." -> ".$row['action']."<br />";
}