ITPub博客

首页 > Linux操作系统 > Linux操作系统 > Oracle中如何解决动态SQL语句过长的问题

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

原创 Linux操作系统 作者:NinGoo 时间:2019-03-07 22:12:05 0 删除 编辑

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;
/

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/193161/viewspace-50287/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 过年回家之交通
请登录后发表评论 登录
全部评论

注册时间:2004-12-07

  • 博文量
    200
  • 访问量
    133382