oracle多数转换

时间:2012-04-24 18:52:31

标签: sql oracle oracle10g

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

  

ORA-00997:非法使用LONG数据类型

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'))
/

3 个答案:

答案 0 :(得分:6)

长类型存储大变量长度字符串,它不是数字类型。它有很多局限性。 Oracle文档说:

使用LONG值受以下限制:

  • 一个表只能包含一个LONG列。
  • 您无法创建具有LONG属性的对象类型。
  • LONG列不能出现在WHERE 或完整性约束中(除了它们可以出现在和NOT NULL约束中)。
  • LONG列无法编入索引。
  • LONG无法在正则表达式中指定。
  • 存储的函数返回LONG值。
  • 您可以使用LONG数据类型声明PL / SQL程序单元的变量或参数。但是,您无法从SQL调用程序单元。
  • 在单个SQL语句中,LONG列,更新表和锁定表必须位于同一数据库中。 LONG和LONG RAW列不能在分布式SQL语句中使用,也不能复制。
  • 如果表同时包含LONG和LOB列,则不能将超过4000个字节的数据绑定到同一SQL语句中的LONG和LOB列。但是,您可以将超过4000个字节的数据绑定到LONG或LOB列。

答案 1 :(得分:4)

为了检查或使用LONG列的值,您必须编写一些PL / SQL,类似于

DECLARE
  strHigh_value  VARCHAR2(4000);
BEGIN
  FOR aRow IN (SELECT PARTITION_NAME, HIGH_VALUE
                 FROM ALL_TAB_PARTITIONS
                 WHERE TABLE_OWNER = 'SCHEMA_NAM' AND
                       TABLE_NAME = 'TABLE_NAME')
  LOOP
    strHigh_value := aRow.HIGH_VALUE;

    -- TODO: Manipulate strHigh_value in whatever manner you need

  END LOOP;
END;

分享并享受。

答案 2 :(得分:1)

如果您不想编写任何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,它有点复杂。 挖掘视图代码并将查询重写为:

是必要的
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上测试