oracle存储过程执行动态sql
㈠ oracle 中动态sql什么时候用
动态sql一般用在存储过程中,可以在存储过程中使用DDL或DML语句,如创建删除操作。
语法:execute immediate 'DDL或DML语句'
㈡ oracle 存储过程 动态sql语句
procere bulupdate语法上的错误
参数定义时的数据类型不能指定长度,varchar2(200)改为varchar2
sqlstring里那个加号去掉
open cursor 时,cursor名应该是定义的过程参数cur
㈢ oracle 如何用存储过程来执行查询出来的语句
这是存储过程执行动态sql,具体做法是在存储过程执行
executeimmediate(v_sqlstr);
㈣ 如何在oracle存储过程中执行动态sql语句
时需要在oracle 存储过程中执行动态SQL 语句 ,例如表名是动态的,或字段是动态的,
或查询命令是动态的,可用下面的方法:
set serveroutput ondeclaren number;sql_stmt varchar2(50);
t varchar2(20);beginexecute immediate 'alter session set nls_date_format=''YYYYMMDD''';
t := 't_' || sysdate;
sql_stmt := 'select count(*) from ' || t;
execute immediate sql_stmt into n;
dbms_output.put_line('The number of rows of ' || t || ' is ' || n);end;
如果动态SQL 语句 很长很复杂,则可用包装.
CREATE OR REPLACE PACKAGE test_pkgISTYPE cur_typ IS REF CURSOR;
PROCEDURE test_proc (v_table VARCHAR2,t_cur OUT cur_typ);END;/
CREATE OR REPLACE PACKAGE BODY test_pkgISPROCEDURE test_proc (v_table VARCHAR2,t_cur OUT cur_typ)ISsqlstr VARCHAR2(2000);BEGINsqlstr := 'SELECT * FROM '||v_table;
OPEN t_cur FOR sqlstr;END;END;/
在oracle 中批量导入,导出和删除表名以某些字符开头的表
spool c:\a.sql
㈤ ORACLE存储过程中,可以动态创建表么
需要用到动态sql。
1、首先要给用户赋予权限:
grant create any table to 用户名;
2、创建存储过程:
create procere p_create_table
(v_sql varchar2)--输入建表语句
as
begin
execute immediate v_sql;
end;
3、执行:
㈥ oracle存储过程循环执行SQL语句
实现方式错了,批量移动数据应该使用Cursor,而不是像分页那样每次都查询。
每次都查询可能会导致重复数据。
正确方式应该是打开一个Cursor,循环Cursor来插入,使用计数器来控制每次COMMIT的行数:
declare
TYPE R_CURSOR IS REF CURSOR;
i number;
a1_cursor R_CURSOR;
a1_row A1%ROWTYPE;
begin
open a1_cursor FOR
select ID, NAME from A1;
i := 0;
loop
fetch a1_cursor
into a1_row;
exit when a1_cursor%notfound;
INSERT INTO A2 VALUES a1_row;
i := i + 1;
if i >= 5 then
commit;
i := 0;
end if;
end loop;
close a1_cursor;
commit;
end;
㈦ oracle存储过程sql执行超时
oracle存储过程sql执行超时要优化系统。优化系统步骤:
1、参数默认是30秒,执行的sql超过30秒就会报超时错误。
2、优化sql让执行更快。
3、修改这个参数,在调用执行SQL语句之前。Oracle公司(甲骨文)是全球最大的信息管理软件及服务供应商,成立于1977年,总部位于美国加州Redwoodshore,面向全球开放oracle认证,Oracle开发的关系数据库产品因性能卓越而闻名,Oracle数据库产品为财富排行榜上的前1000家公司所采用。