在PL/SQL使用游标获取数据及动态SQL

1.游标概念:

当在PL/SQL块中执行DML(增删改)时,Oracle会为其分配上下文区(Context Area),游标是指向上下文区的指针

2.  游标分类:

A.  隐式游标

a.  在PL/SQL中使用DML语句时自动创建隐式游标

b.  隐式游标自动声明、打开和关闭,其名为 SQL

c.  通过检查隐式游标的属性可以获得最近执行的DML 语句的信息

d.  隐式游标的属性有:

%FOUND – SQL 语句影响了一行或多行时为 TRUE

%NOTFOUND – SQL 语句没有影响任何行时为TRUE

%ROWCOUNT – SQL 语句影响的行数

%ISOPEN  - 游标是否打开,始终为FALSE

e. 隐式游标的错误处理:NO_DATA_FOUND:没有查询到任何行。TOO_MANY_ROWS:返回多行。

B.  显式游标

a.  显式 游标的使用步骤:

1)  声明显式游标语法:

CURSOR  游标名[(游标参数列表)] [RETURN  返回值规范]   IS   SELECT 语句   [FOR   UPDATE  OF   [列名列表]];

2)  打开显式游标语法:

OPEN  显式游标名 (参数列表);

3)   提取数据语法:

FETCH   游标名   INTO   记录或变量列表;

4)   关闭游标语法:

CLOSE   游标名;

b.  显式游标属性

显式游标名%属性

%FOUND – SQL 语句影响了一行或多行时为 TRUE

%NOTFOUND – SQL 语句没有影响任何行时为TRUE

%ROWCOUNT – SQL 语句影响的行数

%ISOPEN  - 游标是否打开,始终为FALSE

3. 循环游标 :

用于简化游标处理代码、当用户需要从游标中提取所有记录时使用

循环游标的语法如下:

FOR <record_index> IN <cursor_name>

LOOP

<executable statements>

END LOOP;

4. BULK COLLECT

为什么要使用BULK COLLECT?

提交PL/SQL中SELECT语句的查询效率。

原理:减少了PL/SQL与SQL引擎之间的开关次数,因而加速了数据获取的速度

语法:

... BULK COLLECT into 集合

5. REF 游标和游标变量:用于处理运行时动态执行的 SQL 查询

使用游标变量的步骤:

A.  创建游标变量需要两个步骤:

a.  声明 REF 游标类型

b.  声明 REF 游标类型的变量

用于声明 REF 游标类型的语法为:

TYPE <ref_cursor_name> IS REF CURSOR  [RETURN <return_type>];

用于声明REF 游标类型变量的语法:变量名   游标类型名;

B.  打开游标变量的语法如下:

OPEN cursor_name FOR select_statement;

C.  提取数据语法:

a.  FETCH  游标变量名   INTO   接收游标数据的变量 ……;

b.  FETCH   游标变量名  INTO  接收游标结果的集合变量  ….[LIMIT  rows];

D.  关闭游标变量语法:CLOSE   游标变量名 ;

6.  游标变量的优点和限制

A.  游标变量的优点有:

a. 可从不同的 SELECT 语句中提取结果集

b. 可以作为过程的参数进行传递

c. 可以引用游标的所有属性

d. 可以进行赋值运算

B.  使用游标变量的限制:

a. 不能在程序包中声明游标变量

b. FOR UPDATE子句不能与游标变量一起使用

c. 不能使用比较运算符

7.  动态SQL概述

A.  绑定

a.  编译器识别程序中的标识符存储位置的过程。

b.  分类:早期绑定与晚期绑定

B.  动态 SQL 是指在PL/SQL程序执行时生成的 SQL 语句

C.  DDL 语句命令和会话控制语句不能在 PL/SQL 中直接使用,但是可以通过动态 SQL 来执行

D.  两种动态SQL技术

a.  DBMS_SQL包:Oracle 8i以前使用。

b.  本地动态SQL:Oracle 9i以后使用。

对比:本地动态SQL更简单、执行更快。

E.  执行动态SQL

a.  语法1:execute immediate ‘sql语句字符串‘

b.  语法2:open x for ‘sql语句字符串‘

8.  绑定变量

A.  为什么使用绑定变量:减少编译SQL的次数,提交执行效率

B.  绑定变量说明

execute immediate

‘insert into t1(f1,f2) values(:a,:b)‘ using x,y;

注意: using后面的变量与绑定变量根据位置一一对应。  x-->a、y-->b

C.  绑定变量的使用

a. 在SQL*PLUS(命令窗口) 中使用绑定变量

只能在SQL*PLUS交互环境下使用。

b. 在PL/SQL(存储过程和函数)中使用绑定变量

参数引用的已经是绑定变量。

c.  在动态SQL中使用绑定变量

只能绑定字面量(替换具体的值)

不能替换数据库对象名称

d.  在JDBC中使用绑定变量

PreparedStatement对象

9. 动态SQL语法

语法1:execute immediate ‘sql语句字符串‘

语法2:open for ‘sql语句字符串‘

时间: 2024-10-24 12:17:36

在PL/SQL使用游标获取数据及动态SQL的相关文章

in 多个数据使用动态SQL传入字符串

body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI",Tahoma,Helvetica,Sans-Serif,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMingLiU,serif; font-size: 10.5pt; line-height: 1.5;

扩展SQL的灵活性——静态T_SQL和动态SQL

其实我觉得这个博客写在基于web的应用程序开发是最好的,因为目前我们很少在客户端实现排序和过滤功能,而且很多开发采用的都是轻量级的两层模型,所以缺少专门处理数据缓冲和过滤业务,有些人会说,我们可以创建存储过程或者嵌套复杂的控制流程块?但是我想说,这些方案只能解决一部分问题,但是它们带来的问题远远比我想解决的问题要多得多. 问题 出现这个问题是在我们机房合作通过业务逻辑层来拼接字符串来优化D层代码的时候,但是出现这样一个问题:我这里写好了update一张表的所有字段,但是事实上传入的实体值一般仅仅

sql 根据时间获取数据

获取当月数据 MONTH(时间字段)=MONTH(GETDATE()) 计算两个时间差了多少分钟 DATEDIFF(mi,'7:00',convert(nvarchar(5),CreatedTime,108))    或者   datediff(Month,CreatedTime,getdate())=0 SELECT DATEDIFF(mi,'7:00',convert(nvarchar(5),'10:22',108))             --207

SQL Server 分页获取数据

select top 5000 * from ( select top 10000 *,row_number() over(order by MDMZGZD_NM,MDMZGZD_ZGBH) as rowId from ( select * from MDMZGZDMapping where F_YWXTBH IN ('XZSP') AND F_MDMNM in(select MDMZGZD_NM from MDMZGZD ) C order by rowId ) D order by rowI

十步优化SQL Server中的数据访问(转载)

原文地址:http://tech.it168.com/a2009/1125/814/000000814758.shtml 故事开篇:你和你的团队经过不懈努力,终于使网站成功上线,刚开始时,注册用户较少,网站性能表现不错,但随着注册用户的增多,访问速度开始变慢,一些用户开始发来邮件表示抗议,事情变得越来越糟,为了留住用户,你开始着手调查访问变慢的原因. 经过紧张的调查,你发现问题出在数据库上,当应用程序尝试访问/更新数据时,数据库执行得相当慢,再次深入调查数据库后,你发现数据库表增长得很大,有些表

游标和动态SQL

游标类别:静态游标(指在编译的时候,游标就与一个select语句进行了静态绑定的游标.这样的游标仅仅能作用于一个查询语句)和动态游标(就是希望我们的查询语句在执行的时候才跟游标绑定.为了使用动态游标,必须声明游标变量). 动态游标分两种,各自是强类型和弱类型.强类型的动态游标仅仅能支持查询结果与他类型匹配的这样的查询语句.弱类型的动态游标能够支持不论什么的查询语句. 静态游标分为两种,隐式游标和显示游标.显示游标是实用户声明和操作的一种游标.隐式游标是Oracle为全部的数据操作语句自己主动声明

一次动态sql查询订单数据的设计

订单数据一般是变化比较多的数据,查询条件也是比较复杂,如果没有一个规则解释,写接口的变动就会比较频繁:由于个人不喜欢在业务端使用拼接sql的方式,另外本身是做安全出身,业务端的sql拼接容易sql注入,所以不考虑使用:为了满足这个特性,将订单的条件进行了一次划分: 状态.用户.时间.公司.上车地点.下车地点: 第一步: 先处理状态查询, 状态查询定义在t_om_group表中,后台人员可以手动添加状态分组,前端业务只需要状态分组对应哪些状态即可:如: group_id 1 对应 order_st

动态SQL语句

动态SQL语句不仅是指SQL语句是动态拼接而成的,更主要的是SQL语句所使用的对象也是在运行时期才能创建的. 动态SQL语句基础 create or replace function get_tablecount(table_name in varchar2) return pls_integer is sql_query varchar2(32767):='select count(*) from'||table_name; l_return  pls_integer; begin execu

Oracle_PL/SQL(8) 动态sql

动态sql0.pl/sql块的限制 不能执行ddl操作(create.drop.alter): 不能执行部分dcl操作(grant.revoke). 1.语法动态sql:在执行时才能确定要执行的sql语句.在pl/sql块中编写动态sql语句时,需要将sql语句存放到字符串变量中,而且sql可以包含占位符.execute immediate dynamic_stringdynamic_string :是存放要被执行的sql语句的字符串变量. 2.用途可处理: ddl语句(create,alter