如何将条件日期参数传递给 Table 输入步骤?

How to pass conditioned date parameters to Table input step?

我需要根据日期参数将我的 SQL SELECT 基于作业中的多个转换,但我在使其工作时遇到了问题。

计划是:根据以下条件对 begin_date 和 end_date 进行参数化:如果是任何一个月的 1 日,则参数将成为最后一天的第一天和最后一天月;如果不是,则为当月的第一天,直到昨天。

我已经做了什么:基于修改后的 Java 脚本值步骤创建了两个参数,并将它们传递给设置变量,所有这些都在第一个转换中进行。

在倒数第二个转换中,我需要在 SELECT 中使用这些参数。

我尝试过但没有奏效的方法:

1) 使用获取变量获取两者(它们出现在下拉列表中,从那里获取它们),创建到 Table 输入的跳转并更改 SQL 代码到 ${fst} 和 ${lst}。尝试过检查和不检查 'Replace variables in script?'

2) 不使用获取变量,而是将它们写在转换属性的参数选项卡中。也尝试过检查和不检查 'Replace variables in script?'

3) 在第二次转换的作业条目详细信息的高级选项卡中检查'Copy previous results to parameters?'和'Execute for every input now?'。如果它在执行时标记成功,但不执行以下转换。

我想我可能遗漏了一些简单的东西,但无法通过搜索得到答案。

编辑:一些带有解释的屏幕

1) my first transformation which is to set variables

2) my second transformation which i try to get and use the variables

3) 我正在尝试执行的查询(查看 BETWEEN ${fst} AND ${lst} 部分)

WITH cte AS (
SELECT MAX(data_atendimento) AS data_atendimento, MAX(a.id_customer) AS id_customer, MAX(id_atendimento) AS id_atendimento, MAX(operador) AS operador
FROM tb_atendimento a INNER JOIN tb_param_atd p ON a.id_atendimento = p.id_atd
WHERE id_especializacao = 26 
    AND h_data -> 'CPC_OI' IS NULL 
    AND data_atendimento BETWEEN ${FST} AND ${LST} --DATE_TRUNC('month', CURRENT_DATE) AND CURRENT_DATE + INTERVAL '1 DAY' 
GROUP BY CAST(a.id_customer AS VARCHAR) || CAST(data_atendimento AS VARCHAR))
SELECT *, CASE WHEN MAX(data_atendimento) OVER (PARTITION BY id_customer) = data_atendimento THEN true ELSE false END AS ultimo_atendimento FROM cte;

尝试使用占位符 (?) 代替变量。

看看我的水壶转换之一的屏幕截图(类似于您要实现的目标)。 变量"timenow"来自之前一个js修改的步骤,跟你的一样

如果您要使用多个参数,请记住将按照下拉框出现的顺序进行绑定 "Parameters:"(也显示在屏幕截图中)