Если вы не хотите писать PL/SQL попытаться использовать (в общем случае):
select
sys.dbms_metadata_util.long2varchar(4000, 'TABLE_NAME', 'COLUMN_NAME', tp.rowid) as COLUMN_NAME
from
TABLE_NAME tp
where
<your_condition on table TABLE_NAME>
не используют COLUMN_NAME в ... your_condition на столе TABLE_NAME ...
В вашем случае это немного сложнее, потому что вы запрашиваете VIEW. Нужно копаться в коде представления и переписать запрос как:
select PARTITION_NAME, HIGH_VALUE from (
select t.PARTITION_NAME, sys.dbms_metadata_util.long2varchar(4000, 'SYS.TABCOMPART$', 'HIBOUNDVAL', tp.rowid) as high_value
from
all_tab_partitions t, sys.obj$ o, sys.tabcompart$ tp
where
t.table_name = 'TABLE_NAME'
and t.table_owner = 'SCHEMA_NAM'
and o.name = t.table_name
and o.subname = t.partition_name
and o.obj# = tp.obj#(+)
)
where
high_value > to_number(TO_CHAR(TRUNC(ADD_MONTHS(SYSDATE, 1), 'MONTH'), 'YYYYDDD'))
протестирован на Oracle 11g
Что такое ошибка? –
ORA-00997: незаконное использование LONG-типа данных – mahen