【发布时间】:2021-03-19 12:54:55
【问题描述】:
我对 sql 很陌生,一直在尝试使用以下脚本对其进行参数化。
这是我的代码:
select
dc.deviceid,
dc.kernel_time,
dc.crash_time,
dc.crash_process,
dps.start_time,
dps.end_time,
dps.start_kernel_time,
dps.end_kernel_time,
case
when dc.kernel_time between dps.start_kernel_time and dps.end_kernel_time then 1
when dc.crash_time between dps.start_time and dps.end_time then 2
else 3
end as flag,
ROW_NUMBER () over (partition by dc.deviceid, dc.kernel_time,
dc.crash_time, dc.crash_process order by flag) row_num
from dummy.dummy_crashes dc
left outer join (select *
from dummy.dummy_power) as dps
on dc.deviceid = dps.deviceid
and ((dc.kernel_time between (dps.start_kernel_time + 10000) and (dps.end_kernel_time + 10000)) or (dc.crash_time between dps.start_time and dps.end_time))
order by dc.crash_time;
我需要通过将 start_kernel_time 和 end_kernel_time 更改为某个 int 参数值( 在这个例子中显示:10000) 每次。因此,我不想在代码中修改它,而是想用选择的 int 参数创建一个函数并运行这个脚本。那可能吗? 我真的不知道如何实现这一目标。
我的理想想法是这样的:
get_crashes(10000); <-- get records with adding int parameter (in start_kernel_time and end_kernel_time) as 10000
get_crashes(30000); <-- get records with adding int parameter as 30000
get_crashes(80000); <-- get records with adding int parameter as 80000
我真的很想了解如何实现这一目标?
【问题讨论】:
标签: sql postgresql parameters amazon-redshift