sql常用語句大全 如何在oracle存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)sql語句?
如何在oracle存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)sql語句?時(shí)需要在oracle 存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)SQL 語句 ,例如表名是動(dòng)態(tài)的,或字段是動(dòng)態(tài)的,或查詢命令是動(dòng)態(tài)的,可用下面的方法:set serverout
如何在oracle存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)sql語句?
時(shí)需要在oracle 存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)SQL 語句 ,例如表名是動(dòng)態(tài)的,或字段是動(dòng)態(tài)的,
或查詢命令是動(dòng)態(tài)的,可用下面的方法:
set serveroutput ondeclaren numbersql_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
如果動(dòng)態(tài)SQL 語句 很長(zhǎng)很復(fù)雜,則可用包裝.
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 sqlstrENDEND/
在oracle 中批量導(dǎo)入,導(dǎo)出和刪除表名以某些字符開頭的表
spool c:a.sql
oracle存儲(chǔ)過程循環(huán)執(zhí)行SQL語句?
CREATE OR REPLACE PACKAGE BODY PKG_A_TESTPACKAGE IS
PROCEDURE PKG_A_TESTPROCEDURE(PRM_參數(shù) IN VARCHAR2,
PRM_返回值 OUT NUMBER,
PRM_錯(cuò)誤信息 OUT VARCHAR2) IS
TYPE CURSOR_TYPE IS REF CURSOR
CUR_SQL CURSOR_TYPE
TYPE TYP_REC_INFO IS RECORD(
COLUMN VARCHAR2(1000))
LREC_INFO TYP_REC_INFO
BEGIN
PRM_返回值 := 0
-- 循環(huán)獲取查詢SQL
FOR REC_SQL IN (SELECT 查詢SQL FROM 存放SQL的表 WHERE 條件) LOOP
BEGIN
OPEN CUR_SQL FOR REC_SQL.查詢SQL
LOOP
-- 獲取查詢的信息
FETCH CUR_SQL
INTO LREC_INFO --存放查詢結(jié)果,這里只針對(duì)單列的查詢結(jié)果
-- 如果沒有取到退出
EXIT WHEN CUR_SQL%NOTFOUND
END LOOP
CLOSE CUR_SQL
END
END LOOP
EXCEPTION
WHEN OTHERS THEN
PRM_返回值 := -1
PRM_錯(cuò)誤信息 := "執(zhí)行PKG_A_TESTPROCEDURE出錯(cuò)"
END PKG_A_TESTPROCEDURE
END PKG_A_TESTPACKAGE
按照你的思路寫的,具體需要根據(jù)你自己實(shí)際需求修改擴(kuò)充一下