數(shù)據(jù)庫性能優(yōu)化方法 如何在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ǔ)過程中如何執(zhí)行動(dòng)態(tài)SQL語句,詳細(xì)?
有時(shí)需要在oracle存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)SQL語句,例如表名是動(dòng)態(tài)的,或字段是動(dòng)態(tài)的, 或查詢命令是動(dòng)態(tài)的,可用下面的方法: setserveroutputondeclarennumbersql_stmtvarchar2(50) tvarchar2(20)beginexecuteimmediate"altersessionsetnls_date_format=""YYYYMMDD""" t:="t_"||sysdate sql_stmt:="selectcount(*)from"||t executeimmediatesql_stmtinton dbms_output.put_line("Thenumberofrowsof"||t||"is"||n)end 如果動(dòng)態(tài)SQL語句很長(zhǎng)很復(fù)雜,則可用包裝. CREATEORREPLACEPACKAGEtest_pkgISTYPEcur_typISREFCURSOR PROCEDUREtest_proc(v_tableVARCHAR2,t_curOUTcur_typ)END/ CREATEORREPLACEPACKAGEBODYtest_pkgISPROCEDUREtest_proc(v_tableVARCHAR2,t_curOUTcur_typ)ISsqlstrVARCHAR2(2000)BEGINsqlstr:="SELECT*FROM"||v_table OPENt_curFORsqlstrENDEND/ 在oracle中批量導(dǎo)入,導(dǎo)出和刪除表名以某些字符開頭的表 spoolc:a.sql
oracle中動(dòng)態(tài)sql語句,表名為變量,怎么解?
表名可用變量,但一般需要用到動(dòng)態(tài)sql,舉例如下: declare v_date varchar2(8)--定義日期變量 v_sql varchar2(2000)--定義動(dòng)態(tài)sql v_tablename varchar2(20)--定義動(dòng)態(tài)表名 begin select to_char(sysdate,"yyyymmdd") into v_date from dual--取日期變量 v_tablename := "T_"||v_date--為動(dòng)態(tài)表命名 v_sql := "create table "||v_tablename||" (id int, name varchar2(20))"--為動(dòng)態(tài)sql賦值 dbms_output.put_line(v_sql)--打印sql語句 execute immediate v_sql--執(zhí)行動(dòng)態(tài)sql end 執(zhí)行以后,就會(huì)生成以日期命名的表。