• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Oracle的动态SQL和动态游标举例

mysql 搞代码 4年前 (2022-01-09) 25次浏览 已收录 0个评论

–动态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;
本文来源gao($daima.com搞@代@#码8网^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


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Oracle的动态SQL和动态游标举例
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址