oracle存储过程创建表 oracle存储过程中查询动态表名?
oracle存储过程中查询动态表名?
先建立结果表,也就是存放你最终结果的表
create table test
(a varchar2(100),
b varchar2(100))
然后建立存储过程
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"--这个位置的表名必须大写的A和B,col1和col2换成你实际的字段名称
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存储过程动态SQL?
有时需要在oracle 存储过程中执行动态SQL 语句 ,例如表名是动态的,或字段是动态的,或查询命令是动态的,可用下面的方法: 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 如果动态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 sqlstrENDEND/ 在oracle 中批量导入,导出和删除表名以某些字符开头的表 spool c:a.sql
oracle存储过程中如何执行动态SQL语句,详细?
有时需要在oracle存储过程中执行动态SQL语句,例如表名是动态的,或字段是动态的, 或查询命令是动态的,可用下面的方法: 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 如果动态SQL语句很长很复杂,则可用包装. 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中批量导入,导出和删除表名以某些字符开头的表 spoolc:a.sql
ORACLE多人同时执行一条存储过程,会不会有影响?
你这样属于2个事务在操作一个表。如果表中有唯一键,会有一个过程失败的。如果没有唯一键,会写入20000条记录。但是如果存储过程里操作的表是动态传进去的。如果表名不同,同时执行多个这个存储过程是没有影响的。
oracle存储过程创建表 oracle存储过程比直接执行慢 oracle动态拼接表名
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。