0

我的 MySQL 数据库中有一个表,其中包含活动记录。看起来像:

Action_______________Date_________________User________________Location___________Ref Number  
Action 1........1/1/2012.........J Jones.......Home.............00123  
Action 2........2/1/2012.........K Smith.......Work.............00234  
Action 2........2/1/2012.........J Jones.......Home.............00123  
Action 1........4/1/2012.........B Smith.......Home.............00345  
Action 3........5/1/2012.........J Jones.......Mobile...........00123  
ETC  

我正在寻找的是一个查询,它将遍历表,找到第一次出现的动作 1,然后去为相同的参考编号和动作 3 等找到动作 2。

它将对表中每次出现的 Ref Number 执行此操作。

这些需要在 PHP 中显示为单个数据行,即:

Ref No._____________Act1date_____________Act1User_____________Act1location_____________Act2date_____________Act2User__etc  
00123..........1/1/2012..........J Jones............Home....................2/1/2012..........J Jones
00234..........1/1/2012..........J Jones............Work....................2/1/2012..........J Jones  00345..........1/1/2012..........J Jones............Home....................2/1/2012..........B Smith  

还将进行一些计算,即 Action1_date 和 Action2_date 之间的时间差等。

我想不出如何编写查询来做到这一点——有人可以帮忙吗?

提前致谢,

4

1 回答 1

1

只需使用 order by 语句对结果进行排序。

select
    action,
    Date,
    User,
    Location,
    refNumber
from
    yourTable
order by
    refNumber,
    action
于 2012-08-02T08:58:03.183 回答