gpt4 book ai didi

sql - oracle 长到数字的转换

转载 作者:行者123 更新时间:2023-12-04 11:10:14 27 4
gpt4 key购买 nike

我正在尝试从 all_tab_partitions 表中获取当前分区的名称。当我尝试比较 high_value(长数据类型)和数字时。它抛出一个错误:

ORA-00997: illegal use of LONG datatype


SELECT PARTITION_NAME, HIGH_VALUE FROM ALL_TAB_PARTITIONS
WHERE TABLE_OWNER='SCHEMA_NAM'
AND TABLE_NAME='TABLE_NAME'
AND HIGH_VALUE>to_number(TO_CHAR(TRUNC(ADD_MONTHS(SYSDATE, 1), 'MONTH'), 'YYYYDDD'))
/

最佳答案

如果您不想编写任何 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>

不要在表 TABLE_NAME 的 ...your_condition 中使用 COLUMN_NAME ...

在您的情况下,它有点复杂,因为您查询了一个 VIEW。
有必要挖掘 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 上测试

关于sql - oracle 长到数字的转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10304218/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com