`

ORACLE 动态执行SQL语句

 
阅读更多

Oracle 动态SQL
Oracle 动态SQL有两种写法:用 DBMS_SQL 或 execute immediate,建议使用后者。试验步骤如下:

/*** DDL ***/  
begin  
    EXECUTE IMMEDIATE 'drop table temp_1';  
    EXECUTE IMMEDIATE 'create table temp_1(name varchar2(8))';  
end;  
  
/*** DML ***/  
declare  
    v_1 varchar2(8);  
    v_2 varchar2(10);  
    str varchar2(50);  
begin  
    v_1:='测试人员';  
    v_2:='北京';  
    str := 'INSERT INTO test (name ,address) VALUES (:1, :2)';  
    EXECUTE IMMEDIATE str USING v_1, v_2;  
    commit;  
end;  

 

 

 

2.通过字符串拼接

str_sql:='sal';

str_sql:=' select  '|| 'str_sql'  ||' from emp  '  ; 
execute immediate str_sql ;

 动态返回sal字段,注意字段必须加单引号,如果不加单引号则进行文本值处理。

 

  在存储过程中使用动态查询使用into时用法。

str_column:='sal';--查询的列
str_Total:=0;--总和

str_sql:=' select  '|| 'str_column'  ||' from emp  '  ; 
execute immediate str_sql  into str_Total;

 

 

 

 

 

2. 返回单条结果

declare  
    str varchar2(500);  
    c_1 varchar2(10);  
    r_1 test%rowtype;  
begin  
    c_1:='测试人员';  
    str:='select * from test where name=:c WHERE ROWNUM=1';  
    execute immediate str into r_1 using c_1;  
    DBMS_OUTPUT.PUT_LINE(R_1.NAME||R_1.ADDRESS);  
end ;  

 

 

3. 返回结果集

CREATE OR REPLACE package pkg_test as  
    /* 定义ref cursor类型  
    不加return类型,为弱类型,允许动态sql查询,  
    否则为强类型,无法使用动态sql查询;  
    */  
    type myrctype is ref cursor;  
  
    --函数申明  
    function get(intID number) return myrctype;  
end pkg_test;  
/  
  
CREATE OR REPLACE package body pkg_test as  
--函数体  
    function get(intID number) return myrctype is  
        rc myrctype; --定义ref cursor变量  
        sqlstr varchar2(500);  
    begin  
        if intID=0 then  
            --静态测试,直接用select语句直接返回结果  
            open rc for select id,name,sex,address,postcode,birthday from  
student;  
        else  
            --动态sql赋值,用:w_id来申明该变量从外部获得  
            sqlstr := 'select id,name,sex,address,postcode,birthday from student  
where id=:w_id';  
            --动态测试,用sqlstr字符串返回结果,用using关键词传递参数  
            open rc for sqlstr using intid;  
        end if;  
  
        return rc;  
    end get;  
  
end pkg_test;  

 

 

 

 

分享到:
评论

相关推荐

    oracle监听执行sql语句

    ### Oracle监听执行SQL语句详解 #### 一、Oracle监听执行概述 在Oracle数据库管理与维护过程中,有时候我们需要了解应用程序正在执行哪些SQL语句,这不仅有助于性能优化,还可以帮助我们诊断潜在的问题。通过监听...

    存储过程中怎么动态执行sql语句

    ### 动态执行SQL语句在Oracle中的应用 #### 标题解读 “存储过程中怎么动态执行SQL语句”这一标题表明文章将介绍如何在Oracle数据库的存储过程中编写能够动态执行的SQL语句。动态SQL是指在运行时才能确定其具体内容...

    oracle利用批处理文件执行SQL语句,bat连接oracle数据库并执行语句

    在这个场景中,我们可以利用批处理文件来简化Oracle数据库的操作,如删除用户、创建用户、创建表和触发器,以及执行其他SQL语句。 首先,我们需要了解如何在批处理文件中连接Oracle数据库。这通常通过Oracle的...

    oracle 查看当前会话执行的sql语句

    ### Oracle 查看当前会话执行的SQL语句 在Oracle数据库管理中,有时我们需要了解某个特定会话(Session)正在执行哪些SQL语句。这在性能调优、问题诊断等场景下尤为重要。以下将详细介绍如何通过不同的方法来查看...

    Oracle动态执行SQL四种方式的例子

    在Oracle数据库管理中,动态执行SQL语句是一种强大的功能,允许开发者在运行时构建和执行SQL语句,这对于处理不确定或变化的数据结构尤其有用。本文将深入探讨Oracle中动态执行SQL的四种主要方法,并通过具体示例...

    oracle查看执行最慢与查询次数最多的sql语句

    在Oracle数据库管理中,了解SQL语句的执行性能和频率对于系统优化至关重要。本文将详细介绍如何查看Oracle数据库中执行最慢和查询次数最多的SQL语句,以帮助DBA(数据库管理员)识别潜在的性能瓶颈。 首先,我们来...

    Oracle中SQL语句执行效率的查找与解决

    本文将深入探讨Oracle中SQL语句执行效率的查找与解决方法,特别关注于如何识别和优化那些导致性能瓶颈的查询。 ### Oracle SQL执行效率:查找与解决 #### 一、资源消耗分析 在Oracle中,SQL语句执行效率低下通常...

    Oracle Sql语句转换成Mysql Sql语句

    本项目提供了一个Java源码工具,能够帮助用户便捷地将Oracle SQL语句转换为MySQL SQL语句。 Oracle SQL与MySQL SQL的主要差异在于以下几个方面: 1. **数据类型**:Oracle支持的数据类型如NUMBER、LONG、RAW等在...

    Oracle批处理:使用C# 自带Oracle驱动一次执行多条Sql语句

    Oracle批处理是数据库操作中提高效率的重要手段,尤其是在C#编程环境下,利用Oracle的数据驱动进行批处理,可以显著提升大量SQL语句执行的速度。本文将深入探讨如何在C#中利用Oracle自带的驱动来实现批处理,以一次...

    压测Oracle的SQL语句的性能情况

    在Oracle环境中,LR脚本可以用于执行SQL语句,分析响应时间、事务速率等关键性能指标。 "直连Oracle执行SQL进行压测"意味着测试者直接与数据库交互,不通过中间层如应用程序服务器,这能更准确地反映出数据库本身的...

    Oracle数据库sql语句 跟踪器

    Oracle数据库SQL语句跟踪器,通常被称为SQL Monitor,是一种强大的工具,用于监控和分析数据库中的SQL语句执行情况。在Oracle环境中,理解SQL语句的行为是优化数据库性能的关键。SQL Monitor提供实时视图,帮助DBA...

    java定时执行sql语句

    通过配置数据库连接信息和要执行的sql语句,可实现定时执行多个sql语句。 所要执行的语句只能是写死的,可支持sqlserver mysql oracle。 配置说明: config/sys.properties 中指定数据库类型及连接信息,执行间隔...

    [自己开发]一款非常好用的抓取Oracle数据库SQL语句的工具

    Oracle SQL Profiler,自己设计算法写的一款非常好用的抓取Oracle数据库SQL语句的工具,可以再没有源码的情况下监控ORACLE数据库服务器的v$sqlarea视图抓取出从点击开始按钮到点击结束按钮期间执行过的SQL语句。执行...

    oracle常用监控SQL语句集合

    在Oracle数据库管理中,了解和掌握一些常用的监控SQL语句是至关重要的,这些语句能够帮助DBA(数据库管理员)实时了解数据库的运行状态、性能瓶颈以及资源使用情况。"oracle常用监控SQL语句集合"提供了这样的工具集...

    Oracle常用的SQL语句维护

    本文将深入探讨Oracle中常用的SQL语句以及与数据库表空间相关的维护知识。 首先,让我们了解如何在Oracle中创建表空间。表空间是Oracle数据库中存储数据的逻辑单位,它由一个或多个数据文件组成。创建表空间的SQL...

    使用cmd命令在远程oracle服务器上执行sql语句.txt

    该文档是介绍使用cmd命令在远程oracle服务器上执行sql语句 ,请贡献给大家下载!

    oracle Sql语句二

    oracle Sql语句二 oracle Sql语句二

    oracle常用SQL语句(汇总版).docx

    Oracle 常用 SQL 语句汇总 Oracle 是一个功能强大且复杂的关系数据库管理系统,它提供了多种 SQL 语句来管理和操作数据库。在本文中,我们将详细介绍 Oracle 中常用的 SQL 语句,包括数据控制语句(DML)、数据定义...

Global site tag (gtag.js) - Google Analytics