oracle存儲(chǔ)過程創(chuàng)建表 oracle存儲(chǔ)過程中查詢動(dòng)態(tài)表名?
oracle存儲(chǔ)過程中查詢動(dòng)態(tài)表名?先建立結(jié)果表,也就是存放你最終結(jié)果的表create table test(a varchar2(100),b varchar2(100))然后建立存儲(chǔ)過程creat
oracle存儲(chǔ)過程中查詢動(dòng)態(tài)表名?
先建立結(jié)果表,也就是存放你最終結(jié)果的表
create table test
(a varchar2(100),
b varchar2(100))
然后建立存儲(chǔ)過程
create procedure p_insert
as
cursor cur_tbname is
select "insert into test select col1,col2 from "||table_name
from user_tables where table_name like "AA____BB"--這個(gè)位置的表名必須大寫的A和B,col1和col2換成你實(shí)際的字段名稱
begin
open cur_tbname
loop
fetch cur_tbname into v_sql
exit when cur_tbname%notfound
execute immediate v_sql
commit
end loop
end
我最終沒測試,你自己測試一下,看哪有問題吧
Oracle存儲(chǔ)過程動(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 語句 很長很復(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語句很長很復(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多人同時(shí)執(zhí)行一條存儲(chǔ)過程,會(huì)不會(huì)有影響?
你這樣屬于2個(gè)事務(wù)在操作一個(gè)表。如果表中有唯一鍵,會(huì)有一個(gè)過程失敗的。如果沒有唯一鍵,會(huì)寫入20000條記錄。但是如果存儲(chǔ)過程里操作的表是動(dòng)態(tài)傳進(jìn)去的。如果表名不同,同時(shí)執(zhí)行多個(gè)這個(gè)存儲(chǔ)過程是沒有影響的。