首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >或-01422 ORA-06512

或-01422 ORA-06512
EN

Database Administration用户
提问于 2016-01-13 13:34:49
回答 1查看 391关注 0票数 0

有人能帮忙解决这个错误吗?我无法编写这个.thanks的pl/sql查询。

代码语言:javascript
复制
spool 150OMGIddl.sql

    declare c clob;
    begin
   SELECT DBMS_METADATA.GET_DDL('TABLE',u.table_name,'150OMGI') into c from dba_tables u where owner='150OMGI';
   dbms_output.put_line(c);
   dbms_output.put(';');
  end;
/
spool off

错误:

代码语言:javascript
复制
ERROR at line 1:
ORA-01422: exact fetch returns more than requested number of rows
ORA-06512: at line 3

当我运行SELECT DBMS_METADATA.GET_DDL('TABLE',u.table_name,'150OMGI') from dba_tables u where owner='150OMGI';时,我有26行。

EN

回答 1

Database Administration用户

回答已采纳

发布于 2016-01-13 13:45:29

脚本只需要一行。不是你得到的26块。您必须使用游标并遍历所获得的行:

代码语言:javascript
复制
set serveroutput on
DECLARE
  CURSOR CRS IS
    SELECT DBMS_METADATA.GET_DDL('TABLE',u.table_name,'150OMGI')
    FROM   dba_tables u
    WHERE  owner='150OMGI';
  C CLOB;
BEGIN
  OPEN CRS;
  LOOP
    FETCH CRS INTO C;
    EXIT WHEN CRS%NOTFOUND;

    dbms_output.put_line(c);
    dbms_output.put(';');
  END LOOP;
  CLOSE CRS;
END;
/
票数 0
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/126108

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档