mysql oracle游标 动态sql语句_Oracle的动态SQL和动态游标举例

--动态sql和动态游标 declare cnt number; begin execute immediate

--动态sql和动态游标

declare

cnt number;

begin

execute immediate

'select count(*) from emp'

into cnt;

dbms_output.put_line(cnt);

end;

--创建存储过程执行插入语句

create or replace procedure myproc11

(empid in varchar2,empname in varchar2)

is

sql_str varchar(200):='insert into emp values(:a,:b)';

begin

execute immediate sql_str using empid,empname;

commit;

end;

--本过程有两个参数,第一个表示查询类型:0-精确查询 1-模糊查询;

--第二个参数表示查询条件

create or replace procedure myproc12

(query_type in number,empname in varchar2)

is

sql_str varchar(200):='select * from emp ';

cur pck1.myrefcur;

e emp%rowtype;

begin

if query_type=0 then

sql_str:=sql_str||'where emp_name=:1';

else

sql_str:=sql_str||'where emp_name like ''%''||:1||''%''';

end if;

dbms_output.put_line(sql_str);

open cur for sql_str using empname;

loop

fetch cur into e;

exit when cur%notfound;

dbms_output.put_line(e.emp_id||','||e.emp_name);

end loop;

close cur;

end;

--按姓名模糊查询记录总数

create or replace procedure myproc20

(ename in varchar2)

is

cnt number;

begin

execute immediate

'select count(*) from emp where emp_name like ''%''||:n||''%'''

into cnt using ename;

dbms_output.put_line(cnt);

end;

更多Oracle相关信息见Oracle 专题页面 ?tid=12

logo.gif

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值