Oracle中如何解决动态SQL语句过长的问题

Oracle的varchar2类型最大长度为4000,所有,如果动态sql语句过长,就没有办法在一个varchar2变量中存储整个语句,导致execute immediate本地动态sql方式无法使用。但现实中,有些时候确实会碰到超长的动态sql语句,怎么办呢?解决办法就是,使用dbms_sql包,用dbms_sql.varchar2s数组来保存拼接的sql语句,然后执行。


declare
l_sql dbms_sql.varchar2s;
l_cursor number;
l_rows number;
begin
l_cursor := dbms_sql.open_cursor;

l_sql(1) :='create table cols(';
for i in 2..1000 loop
l_sql(i) := 'a'||to_char(i) || ' int,';
end loop;
l_sql(1000) := 'last int)';

dbms_sql.parse(c => l_cursor,
statement => l_sql,
lb => l_sql.first,
ub => l_sql.last,
lfflg => TRUE,
language_flag => dbms_sql.native);

l_rows := dbms_sql.execute(l_cursor);

dbms_sql.close_cursor( l_cursor );
end;
/

请使用浏览器的分享功能分享到微信等