光标给出错误

时间:2009-09-01 07:11:07

标签: sql oracle plsql ora-00933 ora-20000

嗨,我们正在尝试执行以下脚本 正在犯错误

ERROR at line 1:
ORA-20000: Unknown Exception Raised: -933 ORA-00933: SQL command not properly
ended
ORA-06512: at line 23

DECLARE
        l_cursor INTEGER;
        l_output  VARCHAR2(20);
        l_rows   INTEGER;
        l_sql   VARCHAR2(1000);
      BEGIN
        l_cursor := DBMS_SQL.OPEN_CURSOR;
        l_sql := 'SELECT wk_units1 FROM cnt_sls_dm.fct_sales.summary UNION SELECT wk_units2 FROM cnt_sls_dm.fct_sales.summary';  
       DBMS_SQL.PARSE(l_cursor, l_sql, DBMS_SQL.NATIVE);
       DBMS_SQL.DEFINE_COLUMN_CHAR(l_cursor, 1, l_output, 20);
       l_rows := DBMS_SQL.EXECUTE(l_cursor);
       loop
          if DBMS_SQL.FETCH_ROWS(l_cursor) = 0 then
             exit;
          end if;
          DBMS_SQL.COLUMN_VALUE_CHAR(l_cursor, 1, l_output);
          DBMS_OUTPUT.PUT_LINE('Output Text '||l_output);
       end loop;
       DBMS_SQL.CLOSE_CURSOR(l_cursor);
      EXCEPTION
       when others then
             DBMS_SQL.CLOSE_CURSOR(l_cursor);
             raise_application_error(-20000, 'Unknown Exception Raised: '||sqlcode||' '||sqlerrm);
      END;

2 个答案:

答案 0 :(得分:1)

这是什么?

cnt_sls_dm.fct_sales.summary

这不是有效的表格声明。

答案 1 :(得分:0)

在动态SQL语句中遇到错误时,通常会输出实际的SQL语句并在SQLplus中尝试它。