Welcome 微信登录

首页 / 数据库 / MySQL / Oracle的动态SQL和动态游标举例

--动态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 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12        Oracle中translate与replace的使用Oracle计算环比示例相关资讯      Oracle入门教程 
  • 使用SQLT来构建Oracle测试用例  (08/28/2014 06:17:41)
  • Oracle AUTOTRACE 统计信息  (02/18/2013 08:25:40)
  • Linux Oracle服务启动&停止脚本与  (12/16/2012 14:42:37)
  • Oracle入门教程:把表和索引放在不  (07/13/2013 11:21:40)
  • Oracle直接路径加载--append的深度  (02/07/2013 08:26:36)
  • Oracle Connect By用法  (12/16/2012 13:36:10)
本文评论 查看全部评论 (0)
表情: 姓名: 字数