mysql - 跟踪当前和以前的状态

标签 mysql sql informatica

我有一个表,它保存与 process_id 相对应的 statuscreated_timestamp。一旦进程状态发生变化,就会插入一行。因此,具有相同 process_id 的行的数量与与其相关联的状态的数量一样多。 我想使用此数据创建另一个表/ View ,其中一行对应于一个process_id、它的当前状态和它以前的状态。我需要为此创建一个 Informatica 作业,但 SQL 查询也同样有用。
示例输入:

Process_id | Status     | Created 
         1 | In_queue   | 2014-08-01 00:01:01 
         1 | Started    | 2014-08-01 01:03:01 
         1 | In_process | 2014-08-01 01:50:20 
         1 | Complete   | 2014-08-01 03:10:20 

Sample Output: 
Process_id | Previous_status | Current_status | Updated 
         1 | In_process      | Complete       | 2014-08-01 03:10:20

最佳答案

SELECT Process_id, Previous_status, Current_status, Updated 
FROM (
    SELECT
    Process_id, 
    Status AS Current_status, 
    Created AS Updated,
    @prev_state AS Previous_status,
    @prev_state := Status 
    FROM
    your_table t
    , (select @prev_state := null) var_init
    WHERE Process_id = 1
    ORDER BY Created
) sq

更新:

要为所有 Process_id 执行此操作并仅获取每个 Process_id 的最新记录,您可以使用此方法:

SELECT sq.Process_id, sq.Previous_status, sq.Current_status, sq.Updated 
FROM (
    SELECT
    Process_id, 
    Status AS Current_status, 
    Created AS Updated,
    @prev_state := if(@prev_process != Process_id, null, @prev_state),
    @prev_state AS Previous_status,
    @prev_state := Status,
    @prev_process := Process_id
    FROM
    your_table t
    , (select @prev_state := null, @prev_process := null) var_init
    ORDER BY Process_id, Created
) sq
INNER JOIN (
    SELECT Process_id, MAX(Created) AS max_created
    FROM your_table
    GROUP BY Process_id
) max_c
ON sq.Process_id = max_c.Process_id AND sq.Updated = max_c.max_created

关于mysql - 跟踪当前和以前的状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25058355/

相关文章:

mysql - 如何在 ionic 4 客户端应用程序和 Express 服务器之间建立连接?

php - mySQL 排序和不同

MySQL 基于前一行值的约束

mysql - 使用 mysql 合并来自不同表的两列

error-handling - 如何在Informatica中将数据截断捕获为错误

Informatica 存储库查询以获取工作流、 session 、映射和映射的源/目标

hadoop - 如何使用 BDM(Informatica) 将文件从本地文件系统复制到 hdfs 文件系统?

mysql - 从数据库中的笛卡尔坐标中选择极坐标

SQL 获取与另一个表中的值描述相关联的最后日期和值

sql - 切换到在 bcp 中包含列标题