首页 运维知识 关于讲解Oracle动态SQL

关于讲解Oracle动态SQL

declare mysql varchar2(200); — 保存SQL语句(所谓的动态SQL,就是一个可变的变量) begin mysql := \’select 1+1 fr…

declare
  mysql varchar2(200);  -- 保存SQL语句(所谓的动态SQL,就是一个可变的变量)
begin
  mysql := \'select 1+1 from dual\';
  dbms_output.put_line(mysql);
end;
-----------
declare
  mysql varchar2(200);  -- 保存SQL语句(所谓的动态SQL,就是一个可变的变量)
begin
  mysql := \'create table aa(a1 varchar2(100))\';
  execute immediate mysql;
end;

drop table aa;
create table aa(a1 varchar2(100))
select * from aa
--------------------

begin
  create table aa_20180402(a1 varchar2(100));
end;
-------------------
declare
  mysql varchar2(200);  -- 保存SQL语句(所谓的动态SQL,就是一个可变的变量)
  today varchar2(8);
begin
  select to_char(sysdate,\'yyyyMMdd\') into today from dual;
  mysql := \'create table aa_\'|| today ||\'(a1 varchar2(100))\';
  dbms_output.put_line(mysql);  
  execute immediate mysql;
end;


select to_char(sysdate,\'yyyyMMdd\') from dual

-- 二、立刻执行SQL语句,并赋值给某个变量
select * from t_user5
select * from t_user6

create view t_user6 as select * from t_user5
select upper(\'t_user6\') from dual
select OBJECT_TYPE from dba_objects where object_name=upper(\'t_user6\');
select OBJECT_TYPE from dba_objects where object_name=upper(\'t_user5\');
-------------------------------------
select * from tt3
-------------
create or replace procedure p_a1(obj_name in varchar2)
is
  my_str1 varchar2(100);
  xxx tt3%rowtype;
begin
  -- 拼凑1条可执行的动态SQL ,保存sql语句到my_str1 这个变量中
  my_str1 := \'select * from tt3 where user_name=\';
  my_str1 := my_str1 || \'\'\'\';
  my_str1 := my_str1 || obj_name;
  my_str1 := my_str1 || \'\'\'\';
  --dbms_output.put_line(my_str1);  --调试用
  execute immediate my_str1 into xxx;
  dbms_output.put_line(xxx.city); 
end;
------------------------------
-- 三、带参数的动态SQL(可以把结果存储到某个变量)

create or replace procedure p_a1(obj_name in varchar2)
is
  my_str1 varchar2(100);
  xxx tt3%rowtype;
begin
  -- 拼凑1条可执行的动态SQL ,保存sql语句到my_str1 这个变量中
  my_str1 := \'select * from tt3 where user_name=:1\';
  --dbms_output.put_line(my_str1);  --调试用
  execute immediate my_str1 into xxx using \'小明\';
  dbms_output.put_line(xxx.city); 
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提供了多种类型的连接方式,它们之间的区别在于:从相互交叠的不同数据集合中选择用于连接的行时所采用的方法不同。 连接...

发表回复

返回顶部