2016 - 2024

感恩一路有你

静态表和动态表的区别 oracle存储过程中查询动态表名?

浏览量:2027 时间:2021-03-15 19:38:37 作者:admin

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不支持,确实要用过程来写,要动态执行才行。

1楼的语法在ORACLE中不支持

oracle中动态sql语句,表名为变量,怎么解?

  表名可用变量,但一般需要用到动态sql,举例如下:  declare  v_date varchar2(8)--定义日期变量  v_sql varchar2(2000)--定义动态sql  v_tablename varchar2(20)--定义动态表名  begin  select to_char(sysdate,"yyyymmdd") into v_date from dual--取日期变量  v_tablename := "T_"||v_date--为动态表命名  v_sql := "create table "||v_tablename||"  (id int,  name varchar2(20))"--为动态sql赋值  dbms_output.put_line(v_sql)--打印sql语句  execute immediate v_sql--执行动态sql  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动态拼接表名 oracle游标的使用详解

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。