私はORACLE APEX 5.1.1を使用しており、「SQLクエリを返すPL/SQL関数本体」に基づいてグラフを表示します。この機能は、選択リストの値に基づいてSQLクエリを変更します。したがって、選択リストが変更されるたびにチャートが変更されます。私はすべてのクエリと動的アクションが必要で、機能はうまく動作するように設定しました。しかし、グラフには、間違った「ラベルスロット」(x軸のカテゴリ)の値が表示されます。誤ったグラフの表示を明確にするために、まったく同じ機能に基づいた古典的なレポートを作成しました。これは値を正しく表示します。ORACLE APEX 5.1.1:PL/SQL関数に基づくグラフが間違ったラベルの値を表示
https://apex.oracle.comの私の評価勘定にミニマルの例を複製しました。そこにはすべてが、それがあるはずのやり方です。 apex.oracle.comは現在バージョン5.1.3です。だから私はこれが修正されたバージョン5.1.1のバグかどうか疑問に思っています。私は、リリースノートでこの問題について何も見つけることができません。 誰でもこのバグについて知っているのですか、5.1.1で私の問題を助けてくれますか?残念ながら私の企業環境では5.1.3にアップグレードすることはできません。
declare
q varchar2(32767);
begin
q :=
'
select
type1, type2, sum(to_number(val)) as val
from (
SELECT ''a'' as type1, ''x'' as type2, ''1'' as val
FROM DUAL
UNION ALL
SELECT ''a'' as type1, ''y'' as type2, ''2'' as val
FROM DUAL
UNION ALL
SELECT ''a'' as type1, ''z'' as type2, ''3'' as val
FROM DUAL
UNION ALL
SELECT ''b'' as type1, ''x'' as type2, ''3'' as val
FROM DUAL
UNION ALL
SELECT ''b'' as type1, ''z'' as type2, ''3'' as val
FROM DUAL
UNION ALL
SELECT ''c'' as type1, ''x'' as type2, ''2'' as val
FROM DUAL
UNION ALL
SELECT ''c'' as type1, ''y'' as type2, ''-2'' as val
FROM DUAL
UNION ALL
SELECT ''d'' as type1, ''y'' as type2, ''-3'' as val
FROM DUAL
UNION ALL
SELECT ''d'' as type1, ''z'' as type2, ''1'' as val
FROM DUAL
UNION ALL
SELECT ''e'' as type1, ''x'' as type2, ''1'' as val
FROM DUAL
UNION ALL
SELECT ''a'' as type1, ''z'' as type2, ''3'' as val
FROM DUAL
)
'
;
if :TEST_VALS = 'only positive' then q := q || ' where val >= 0';
elsif :TEST_VALS = 'only negative' then q := q || ' where val <= 0';
end if;
q := q || ' group by type1, type2 order by type1, type2';
return q;
end;
:TEST_VALS
all, only positive, only negative
と静的選択リストを参照:
は、ここで私は両方のために使用するPL/SQL、古典的なレポートやチャートです。ダイナミックアクションは、選択リストの変更時にリフレッシュ、クラシックレポートおよびチャートに「送信するページアイテム」を設定します。
以下に、5.1.1のバグと5.1.3の正しいチャート表示を示す3つのスクリーンショットを示します。 "全て" 5.1.1および選択に