`

PL/SQL执行动态SQL(二)

阅读更多
PL/SQL动态SQL

依据:
DBMS_SQL包:这个包提供了一种使用动态sql来访问数据库的方法。

示例
1.执行插入删除等DML语句
declare
  v_cursorid number;
  v_insertRecords varchar2(500);
  v_numrows integer;
begin
  v_cursorid := dbms_sql.open_cursor;
  v_insertRecords := 'delete from bizbusinessmenuinfo where menubizname=:bizname';
  dbms_sql.parse(v_cursorid,v_insertrecords,dbms_sql.native);
  dbms_sql.bind_variable(v_cursorid,':bizname','1');
  v_numrows := dbms_sql.execute(v_cursorId);
  dbms_output.put_line(v_numrows);
  exception
    when others then raise;
  dbms_sql.close_cursor(v_cursorid);
  commit;
end;


2.执行动态DDL
declare
  v_cursorid number;
  v_createTableString varchar2(500);
  v_numrows integer;
begin
  v_cursorid := dbms_sql.open_cursor;
  v_createTableString := 'create table bizbusinessbaseinfo(bizname varchar2(64),bizstatus char(1))';
  dbms_sql.parse(v_cursorid,v_createTableString,dbms_sql.native);
  v_numrows := dbms_sql.execute(v_cursorid);
  exception
    when others then
    if sqlcode!=-955 then raise;
    else
       dbms_output.put_line('talbe already exists');
    end if;
  dbms_sql.close_cursor(v_cursorId);
end;


3.动态查询query
declare
  v_cursorid number;
  v_selectrecords varchar2(500);
  v_numrows integer;
  v_bizname varchar2(64);
  v_bizstatus char(1);
begin
  v_cursorid := dbms_sql.open_cursor;
  v_selectrecords := 'select bizname,bizstatus from bizbusinessbaseinfo where bizname like :bizname';
  dbms_sql.parse(v_cursorid,v_selectrecords,dbms_sql.native);
  --dbms_sql.define_column绑定变量的时候,变量如果是字符串,需要执行长度,否则会出现错误: 有太多的 'DEFINE_COLUMN' 说明与此次调用相匹配 
  dbms_sql.define_column(v_cursorid,1,v_bizname,64);
  dbms_sql.define_column(v_cursorid,2,v_bizstatus,1);  
  dbms_sql.bind_variable(v_cursorid,':bizname','1%');
  v_numrows := dbms_sql.execute(v_cursorid);
  loop
    if dbms_sql.fetch_rows(v_cursorid)=0 then exit;
    end if;
    dbms_sql.column_value(v_cursorid,1,v_bizname);
    dbms_sql.column_value(v_cursorid,2,v_bizstatus);
    dbms_output.put_line(v_bizname||'  '||v_bizstatus);
  end loop;

  dbms_sql.close_cursor(v_cursorid);
end;


4.动态查询的dbms_sql.last_row_count和dbms_sql.last_row_id
这两个字段可以反映出当前检索的进度。在上面的查询中加入对这两个字段的输出,示例如下:
declare
  v_cursorid number;
  v_selectrecords varchar2(500);
  v_numrows integer;
  v_bizname varchar2(64);
  v_bizstatus char(1);

v_myrowid rowid;
v_totrow integer;
begin
  v_cursorid := dbms_sql.open_cursor;
  v_selectrecords := 'select bizname,bizstatus from bizbusinessbaseinfo where bizname like :bizname';
  dbms_sql.parse(v_cursorid,v_selectrecords,dbms_sql.native);
  --dbms_sql.define_column绑定变量的时候,变量如果是字符串,需要执行长度,否则会出现错误: 有太多的 'DEFINE_COLUMN' 说明与此次调用相匹配 
  dbms_sql.define_column(v_cursorid,1,v_bizname,64);
  dbms_sql.define_column(v_cursorid,2,v_bizstatus,1);  
  dbms_sql.bind_variable(v_cursorid,':bizname','1%');
  v_numrows := dbms_sql.execute(v_cursorid);

  v_numrows := dbms_sql.execute(v_cursorid);

  loop
    if dbms_sql.fetch_rows(v_cursorid)=0 then exit;
    end if;

    v_totrow := dbms_sql.last_row_count;
    v_myrowid := dbms_sql.last_row_id;
    dbms_output.put_line('the last row count is:'||v_totrow||
    '  the last rowid is:'||v_myrowid);

    dbms_sql.column_value(v_cursorid,1,v_bizname);
    dbms_sql.column_value(v_cursorid,2,v_bizstatus);
    dbms_output.put_line(v_bizname||'  '||v_bizstatus);
  end loop;
dbms_sql.close_cursor(v_cursorid);
end;

分享到:
评论

相关推荐

    一个对数据库的操作工具PL/SQLpl/sqL工具

    8. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以执行在运行时构建的SQL语句,增强了程序的动态性。 9. **数据库链接**:允许用户从一个数据库访问另一个数据库的数据,实现分布式数据库操作。 10. **性能优化**...

    oracle10g_pl/sql

    - **嵌套SQL**:在PL/SQL代码中执行SQL查询,如SELECT INTO语句。 - **游标**:用于处理查询结果集,允许逐行访问数据。 5. **PL/SQL高级特性** - **记录类型**:自定义的数据结构,可以包含多个列。 - **表...

    pl/sql最新中文手册

    8. **索引和性能优化**:手册可能也会涉及如何利用索引来提高PL/SQL程序的执行效率,以及如何分析和优化SQL语句。 9. **并发和锁定**:在多用户环境下,理解并发控制和锁定机制是必要的。手册可能会讨论如何处理...

    pl/sql developer11.0

    PL/SQL Developer是一款由Allround Automations公司开发的专业Oracle数据库开发工具,专为编写、调试、测试和管理PL/SQL代码而设计。标题中的“pl/sql developer11.0”指的是该软件的第11个主要版本。在本文中,我们...

    Oracle PL/SQL实战(待续)

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据处理能力与PL的程序设计特性,是Oracle数据库系统中用于创建存储过程、函数、触发器和包的主要工具。在这个"Oracle PL/SQL实战(待续)"的主题中,我们将深入...

    pl/sql64位

    PL/SQL是Oracle数据库系统中的一个关键组件,全称为Procedural Language/Structured Query Language,是一种结合了SQL和过程编程语言的工具,主要用于编写数据库应用程序。64位的PL/SQL开发者工具对于那些处理大数据...

    oracle 9i pl/sql程序设计笔记

    ### Oracle 9i PL/SQL程序设计笔记精要 #### PL/SQL基础知识概览 **标题与描述**:本文档围绕“Oracle 9i PL/SQL程序设计笔记”这一核心主题,深入探讨了PL/SQL语言的基础知识及其在Oracle 9i数据库环境中的应用。...

    pl/sql 免安装,绿色版pl/sql

    它提供了对PL/SQL代码的编写、调试、执行以及数据库对象的管理等功能。通过这个工具,你可以轻松地查看、编辑和执行SQL查询,管理表、视图、存储过程、触发器等数据库对象,同时还能进行数据导入导出和数据库备份...

    PL/SQL VCS插件安装包+PL/SQL

    VCS插件将VSS的这些功能无缝集成到PL/SQL Developer中,允许开发者直接在PL/SQL环境中执行版本控制操作,如添加、删除、检查出、提交代码。 在安装PL/SQL VCS插件的过程中,用户需要首先确保已经安装了PL/SQL ...

    Oracle PL/SQL程序设计(第5版)(上下册)

    - **动态SQL**:探讨如何构造和执行动态SQL语句,这对于需要根据运行时条件生成SQL的情况非常有用。 - **SQL*Plus命令**:介绍一些常用的SQL*Plus命令,如SET、SPOOL、COLUMN等,这些命令可以增强SQL查询的输出格式...

    oracle pl/sql从入门到精通 配套源代码

    PL/SQL是Oracle数据库的内置编程语言,由块构成,包括声明部分、执行部分和异常处理部分。块可以是匿名块(即直接在SQL*Plus或其他工具中编写的一次性执行的代码),也可以是存储过程、函数、触发器、包等可重用的...

    PL/SQL 基本知识

    例如,在`jbpm.sql`文件中,可能包含了与业务流程管理(BPM)相关的PL/SQL存储过程或函数,用于定义和执行工作流任务。 此外,PL/SQL还支持块的概念,如匿名块,这使得在不创建独立的存储过程或函数的情况下,也能...

    pl/sql快捷插件

    这款软件为Oracle数据库管理员、开发人员和测试人员提供了便捷的SQL和PL/SQL编写、调试和执行功能。而“pl/sql快捷插件”则是针对PL/SQL Developer的一个增强工具,它旨在提高用户的开发效率和工作流程。 PL/SQL...

    PL/SQL Developer 远程连接Oracle数据库

    8. **性能监控**:尽管是远程连接,PL/SQL Developer仍然可以显示执行计划、统计信息和性能指标,帮助分析和优化SQL查询。 9. **版本控制集成**:PL/SQL Developer可以与各种版本控制系统(如Git、SVN)集成,这...

    PL/SQL编程基础知识

    如果需要在PL/SQL中执行DDL操作,则需要通过动态SQL来实现。 #### 二、PL/SQL块结构 **2.1 PL/SQL块** PL/SQL程序通常由以下三个部分组成: - **声明部分**:用于声明变量、游标、局部存储过程和函数等。 - **...

    PL/SQL下载

    5. **动态SQL**:允许在运行时构造和执行SQL语句,增强了灵活性。 **PL/SQL Developer** PL/SQL Developer是一款专为Oracle数据库开发设计的集成开发环境(IDE),它的主要功能包括: 1. **源代码编辑器**:提供...

    Oracle PL/SQL实例编程(PL/SQL经典书籍)

    1. **基础语法**:PL/SQL是过程化SQL,它包含声明部分、执行部分和异常处理部分。声明部分用于定义变量、常量和游标;执行部分包含了SQL语句和流程控制结构,如循环、条件判断等;异常处理部分则用于捕获和处理运行...

    Oracle PL/SQL程序设计(第5版)(套装上下册)

    《Oracle PL/SQL程序设计(第5版)(套装上下册)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何...

    ORACLE PL/SQL从入门到精通

    过程是PL/SQL中一种用来封装逻辑的单元,它包含了一系列的SQL语句和PL/SQL代码,可以执行特定的任务。过程与匿名程序块的区别在于它具有名称和参数,能够被重复调用。创建过程的语法中涉及到参数模式,包括IN、OUT、...

    PL/SQL doc 文件

    本文将讲述 PL/SQL 基础语法、结构和组件、以及如何设计并执行一个 PL/SQL 程序。 PL/SQL 的优点包括: * 高性能的基于事务处理的语言,能运行在任何 ORACLE 环境中,支持所有数据处理命令。 * 支持所有 SQL 数据...

Global site tag (gtag.js) - Google Analytics