Една от възможностите е да използвате WITH
клауза за присвояване на вашите параметри на фиктивна таблица.
WITH tmp_parms AS (
SELECT ? as fr_dt, ? as to_dt, ? as p_comp_code,
? as fr_cat, ? as to_cat, ? as p_sub_code
FROM dual
)
SELECT C.COMP_CODE,C.MATCODE, ... etc
FROM tmp_parms tp,
(
SELECT A.COMP_CODE,A.MATCODE, ... etc
Или ако предпочитате още един вграден изглед:
SELECT C.COMP_CODE,C.MATCODE, ... etc
FROM (
SELECT ? as fr_dt, ? as to_dt, ? as p_comp_code,
? as fr_cat, ? as to_cat, ? as p_sub_code
FROM dual
) tp,
(
SELECT A.COMP_CODE,A.MATCODE, ... etc
И след това заменете всички съществуващи променливи за свързване с препратки към еквивалентната колона от временната таблица parms, т.е. променете това:
b.grn_date<=:TO_DT)
към това:
b.grn_date<=tp.to_dt)