Heim >Datenbank >MySQL-Tutorial >Oracle 9i环境运行10g下的sql脚本出现不兼容的问题

Oracle 9i环境运行10g下的sql脚本出现不兼容的问题

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-06-07 17:25:581081Durchsuche

在Oracle 10g环境中运行没有任何问题,但在Oracle 9i执行中,会莫名其妙地报错 ORA-22905: cannot access rows from a non-neste

在Oracle 10g环境中运行没有任何问题,如下:

FOR C IN (SELECT * FROM TABLE(PKG_CMD_COMMON.F_SPLIT(P_IN_IDS_, ','))) LOOP
。。。。此处省略
END LOOP;

但在Oracle 9i执行中,,会莫名其妙地报错 ORA-22905: cannot access rows from a non-nested table item无法从非嵌套表项访问行。

分析:

包pkg_cmd_common中的函数f_split返回的是type类型的自定义的数组type_varchar_array

在网上查知:oracle9i下需要cast转换

FOR C IN (SELECT * FROM TABLE(CAST(PKG_CMD_COMMON.F_SPLIT(P_IN_IDS_, ',') AS TYPE_VARCHAR_ARRAY))) LOOP
。。。。此处省略
END LOOP;

重新编译后不再报错,至此问题解决,在这里记录下。

linux

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn