首页 运维知识 关于Oracle 动态sql

关于Oracle 动态sql

静态SQL是前置编译绑定,动态SQL是后期执行时才编译绑定。 场景: 动态SQL适用于表名及查询字段名未知的情况。在已知查询字段名及表名的情况下,使用动态SQL(字符串拼接方式)会…

静态SQL是前置编译绑定,动态SQL是后期执行时才编译绑定。

场景:

动态SQL适用于表名及查询字段名未知的情况。在已知查询字段名及表名的情况下,使用动态SQL(字符串拼接方式)会增加硬解析的开销,在这种情况下,建议使用静态SQL,这样可以提高执行效率。在过程过程用拼凑的动态sql效率并不高。

因此,真实业务下适用动态sql的场景非常少,使用时也必须注意表结构的变动等因素,应该尽量在业务开发中使用动态sql。本人一般使用动态sql做数据采集;

用execute immediate实现动态sql:

----ddl
begin
  execute immediate \'create table l_test(name varchar2(8))\';
end;

带参数:

declare
  ----带参数
  v_name  l_test.name%type;
  v_insql varchar(100);

begin
  v_name  := \'张三\';
  v_insql := \'insert into l_test(name)values(:1)\';
  execute immediate v_insql
    using v_name;
  commit;
end;

关于Oracle 动态sql插图

返回一行记录:

declare
  ----带参数
  v_name  l_test.name%type;
  v_sql varchar(100);

  v_rec l_test%rowtype;

begin
  v_name := \'张三\';
  v_sql  := \'select * from l_test t where t.name=:v_n\';
  execute immediate v_sql
    into v_rec
    using v_name;
  dbms_output.put_line(v_rec.name);
end;

返回多行记录:

declare
  --v_name l_test.name%type;
  v_sql  varchar(100);

  type t_rec IS TABLE OF l_test%ROWTYPE;
  v_arry_test t_rec;

begin
  v_name := \'张三\';
  v_sql  := \'select * from l_test t\';
  execute immediate v_sql bulk collect
    into v_arry_test;

  for i in 1 .. v_arry_test.count loop
    dbms_output.put_line(v_arry_test(i).name);
  end loop;

end;

关于Oracle 动态sql插图1

 

结合游标:

declare
  v_name l_test.name%type;
  v_sql  varchar(100);
  type cur_type is ref cursor;
  v_cur cur_type;
  type t_rec IS TABLE OF l_test%ROWTYPE;
  v_arry_test t_rec;

begin
  v_name := \'张三\';
  v_sql  := \'select * from l_test t where name=:v_n\';

  open v_cur for \'\' || v_sql
    using v_name;
  fetch v_cur bulk collect
    into v_arry_test;
  close v_cur;
  for i in 1 .. v_arry_test.count loop
    dbms_output.put_line(v_arry_test(i).name);
  end loop;
end;
免责声明:文章内容不代表本站立场,本站不对其内容的真实性、完整性、准确性给予任何担保、暗示和承诺,仅供读者参考,文章版权归原作者所有。如本文内容影响到您的合法权益(内容、图片等),请及时联系本站,我们会及时删除处理。

作者: 小小编

为您推荐

dell R710 更换raid卡后,raid卡信息没有了,处理方案

dell R710 更换raid卡后,raid卡信息没有了,处理方案

1.将一台服务器(A)的硬盘依次拔出,按相同顺序插入另一台同样配置的服务器(B) 2.启动服务器(B) 3.按提示键盘按...
PL SQL Developer 13连接Oracle数据库并导出数据详细操作教程方法

PL SQL Developer 13连接Oracle数据库并导出数据详细操作教程方法

下载 并安装 PL SQL Developer 13,默认支持中文语言 ========================...
关于一条sql语句在mysql中是如何执行的

关于一条sql语句在mysql中是如何执行的

最近开始在学习mysql相关知识,自己根据学到的知识点,根据自己的理解整理分享出来,本篇文章会分析下一个sql语句在my...
关于sql注入姿势总结(mysql)

关于sql注入姿势总结(mysql)

前言 学习了sql注入很长时间,但是仍然没有系统的了解过,这次总结一波,用作学习的资料。 从注入方法分:基于报错、基于布...
关于Oracle SQL外连接

关于Oracle SQL外连接

SQL提供了多种类型的连接方式,它们之间的区别在于:从相互交叠的不同数据集合中选择用于连接的行时所采用的方法不同。 连接...

发表回复

返回顶部