当前位置:首页 » 存储配置 » oracle存储过程拼接sql

oracle存储过程拼接sql

发布时间: 2022-08-26 23:52:43

㈠ oracle存储过程条件查询

--先在包里面定义一个指针类型mycur供后续存储过程使用
create or replace package PKG_STUDENT_OPEAR is
type mycur is ref cursor;
end PKG_STUDENT_OPEAR;

--定义存储过程,里面根据参数拼接sql语句,最终得到结果
create or replace procere query_temp(in_a in varchar2,
in_b in varchar2,
in_c in varchar2,
in_d in varchar2,
rescur out PKG_STUDENT_OPEAR.mycur) is
str_sql varchar2(500);
begin
str_sql := 'select tt.* from table tt where 1=1 ';
if in_a is not null or nvl(in_a, 'null') <> 'null' then
str_sql := str_sql || ' and tt.a = ''' || in_a || '''';
end if;
if in_b is not null or nvl(in_b, 'null') <> 'null' then
str_sql := str_sql || ' and tt.b = ''' || in_b || '''';
end if;
if in_c is not null or nvl(in_c, 'null') <> 'null' then
str_sql := str_sql || ' and tt.c = ''' || in_c || '''';
end if;
if in_d is not null or nvl(in_d, 'null') <> 'null' then
str_sql := str_sql || ' and tt.d = ''' || in_d || '''';
end if;
open rescur for str_sql;
end query_temp;

㈡ oracle 利用存储过程循环执行sql语句

你的需求不需要使用存储过程的,一个简单的聚合函数就能实现吧。

用存储过程反而麻烦,你想用的话,可以学习一下pl/sql相关的内容。

㈢ 关于oracle存储过程中的sql拼接,大神进!!!

procere proc_test(
in_id in varchar2,
out_sum out varchar2
) as
begin
execute immediate 'select count(*) from table_name '||in_id into out_sum;
end;
/
sqlplus里调用时:
var out_sum varchar2(10)
exec package_name.proc_test('where id=''XXX'' or 1=1',:out_sum)
print out_sum

㈣ oracle存储过程中如何执行动态SQL语句 详细�0�3

有时需要在oracle 存储过程中执行动态SQL 语句 ,例如表名是动态的,或字段是动态的,
或查询命令是动态的,可用下面的方法:
set serveroutput ondeclaren number;sql_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 sqlstr;END;END;/
在oracle 中批量导入,导出和删除表名以某些字符开头的表
spool c:\a.sql

㈤ oracle存储过程中如何执行动态SQL语句 详细

有时需要在oracle
存储过程中执行动态SQL
语句
,例如表名是动态的,或字段是动态的,
或查询命令是动态的,可用下面的方法:
set
serveroutput
ondeclaren
number;sql_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
sqlstr;END;END;/
在oracle
中批量导入,导出和删除表名以某些字符开头的表
spool
c:\a.sql

㈥ Oracle [存储过程] 执行动态拼接SQL语句并返回结果

建议你用 instr函数,v_sql条件改为
where instr(p_jbm,t.jbm)>0试试吧。

㈦ Oracle 怎么把存储过程传过来的参数拼接成

给你一个 传递参数的例子

SQL> CREATE OR REPLACE PROCEDURE HelloWorld2 (
2 p_user_name IN VARCHAR2,
3 p_out_val OUT VARCHAR2,
4 p_inout_val IN OUT VARCHAR2
5 ) AS
6 BEGIN
7 dbms_output.put_line('Hello ' || p_user_name || p_inout_val || '!');
8 p_out_val := 'A';
9 p_inout_val := 'B';
10 END HelloWorld2;
11 /

Procere created.

SQL> DECLARE
2 p_outval VARCHAR2(10);
3 p_inoutval VARCHAR2(10) := '~Hi~';
4 BEGIN
5 HelloWorld2('Edward', p_outval, p_inoutval);
6
7 dbms_output.put_line('p_outval=' || p_outval);
8 dbms_output.put_line('p_inoutval=' || p_inoutval);
9 END;
10 /
Hello Edward~Hi~!
p_outval=A
p_inoutval=B

PL/SQL procere successfully completed.

SQL>

㈧ 在oracle 存储过程中,动态创建临时表后,执行一段很长的insert 语句,应该怎么弄呢

通过拼接sql语句赋给变量如v_sql
然后再用execute immediate v_sql执行即可实现。

java调用oracle存储过程 关于sql里面in函数参数的问题

调用存储过程是java 把组合起来的字符串传到数据库后台操作,如果你in ( pkStagesPersonArray),传到数据库后台还是 in ( pkStagesPersonArray) 而非你想要的 in('1330251','1336140' )所以你应该把pkStagesPersonArray 里面的内容转换成 '1330251','1336140' 再拼接起来

热点内容
磁力片编程课 发布:2024-12-22 14:10:57 浏览:271
小米6实际存储空间 发布:2024-12-22 13:41:25 浏览:594
sql注入补丁 发布:2024-12-22 13:32:58 浏览:120
小区高层消防逃生怎么配置 发布:2024-12-22 13:29:20 浏览:717
服务器配置光纤网卡ip 发布:2024-12-22 13:22:47 浏览:516
地图下载源码 发布:2024-12-22 13:18:40 浏览:394
navicat存储过程导出 发布:2024-12-22 13:12:44 浏览:300
androidservice线程 发布:2024-12-22 13:04:57 浏览:302
ntplinux服务器配置 发布:2024-12-22 12:28:23 浏览:268
android模拟机 发布:2024-12-22 12:26:08 浏览:609