ORACLE 包内的存储过程的动态sql
2013-04-03 20:16
330 查看
--
---创建包
create or replace package test_pkg is
g_public_flag varchar2(1);
function test_function(p_param1 varchar2,
p_param2 varchar2) return varchar2;
function hello_function(p_param3 varchar2) return varchar2;
procedure ff(p1 varchar2);
end;
--包体
create or replace package body test_pkg is
g_private_flag varchar2(1) := 'Y';
function test_function(p_param1 varchar2,
p_param2 varchar2) return varchar2
is
val varchar2(10):='hello';
begin
dbms_output.put_line('helo');
return val;
end ;
function hello_function(p_param3 varchar2) --参数与包头中必须保持一致
return varchar2 is
val varchar2(10):='hello';
begin
dbms_output.put_line('world');
return val;
end;
procedure ff(p1 varchar2) is
flag number;
pp1 VARCHAR2(10):='p';
p2 VARCHAR2(10):='p';
p3 VARCHAR2(10):='p';
p4 VARCHAR2(10):='p';
begin
select count(*)into flag from all_all_tables where table_name='LOGTABLE1';
dbms_output.put_line(flag);
if(flag = 0) then
execute immediate
'CREATE TABLE logtable1 (userid VARCHAR2(10), logdate VARCHAR2(10),exception_id VARCHAR2(10),exception_msg VARCHAR2(10))';
end if;
execute immediate 'insert into logtable1 values (:1,:2,:3,:4)' using '1','1','2','3'; --只能动态插入
end;
end;
----测试
declare
begin
dbms_output.put_line(test_pkg.test_function('1','1'));
dbms_output.put_line(test_pkg.hello_function('1'));
test_pkg.ff('dd');
end;
select * from logtable1;
drop table logtable1
---创建包
create or replace package test_pkg is
g_public_flag varchar2(1);
function test_function(p_param1 varchar2,
p_param2 varchar2) return varchar2;
function hello_function(p_param3 varchar2) return varchar2;
procedure ff(p1 varchar2);
end;
--包体
create or replace package body test_pkg is
g_private_flag varchar2(1) := 'Y';
function test_function(p_param1 varchar2,
p_param2 varchar2) return varchar2
is
val varchar2(10):='hello';
begin
dbms_output.put_line('helo');
return val;
end ;
function hello_function(p_param3 varchar2) --参数与包头中必须保持一致
return varchar2 is
val varchar2(10):='hello';
begin
dbms_output.put_line('world');
return val;
end;
procedure ff(p1 varchar2) is
flag number;
pp1 VARCHAR2(10):='p';
p2 VARCHAR2(10):='p';
p3 VARCHAR2(10):='p';
p4 VARCHAR2(10):='p';
begin
select count(*)into flag from all_all_tables where table_name='LOGTABLE1';
dbms_output.put_line(flag);
if(flag = 0) then
execute immediate
'CREATE TABLE logtable1 (userid VARCHAR2(10), logdate VARCHAR2(10),exception_id VARCHAR2(10),exception_msg VARCHAR2(10))';
end if;
execute immediate 'insert into logtable1 values (:1,:2,:3,:4)' using '1','1','2','3'; --只能动态插入
end;
end;
----测试
declare
begin
dbms_output.put_line(test_pkg.test_function('1','1'));
dbms_output.put_line(test_pkg.hello_function('1'));
test_pkg.ff('dd');
end;
select * from logtable1;
drop table logtable1
相关文章推荐
- oracle存储过程中应用动态sql
- oracle存储过程定义游标用动态sql
- ORACLE 包内的存储过程的动态sql
- 简单搞一下 Oracle 存储过程动态SQL之获取查询分页!
- oracle 在存储过程中定义动态sql
- oracle execute immediate 动态执行SQL存储过程
- oracle存储过程执行动态sql
- oracle 存储过程执行动态sql返回游标
- oracle 动态SQL在存储过程中的使用
- oracle 调用动态存储过程,动态sql
- oracle存储过程如何定义,动态判断条件sql如何书写
- Oracle 动态SQL语句(3)之保存存储过程
- oracle存储过程中如何执行动态SQL语句
- Oracle 存储过程及函数中游标+动态的sql处理
- ORACLE动态sql在存储过程中出现表或视图不存在的解决方法
- Oracle 动态SQL语句(4)之存储过程的调用与浅谈字符串的使用
- oracle存储过程中如何执行动态SQL语句
- sql server、db2、oracle 存储过程动态sql语句示例
- Oracle存储过程执行动态sql
- oracle动态sql:存储过程中动态调用存储过程,并且动态调用的存储过程出参数游标