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家公司所採用。