在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语句字符串'
在PL/SQL使用游标获取数据及动态SQL的更多相关文章
- 如何用asp.net MVC框架、highChart库从sql server数据库获取数据动态生成柱状图
如何用asp.net MVC框架.highChart库从sql server数据库获取数据动态生成柱状图?效果大概是这样的,如图: 请问大侠这个这么实现呢?
- ajax异步获取数据后动态向表格中添加数据(行)
因为某些原因,项目中突然需要做自己做个ajax异步获取数据后动态向表格中添加数据的页面,网上找了半天都没有 看到现成的,决定自己写个例子 1.HTML页面 <!doctype html> ...
- 【PL/SQL系列】Oracle存储过程使用动态SQL
Oracle存储过程相信大家都比较了解,下面就为您介绍Oracle存储过程使用动态SQL的方法,希望对您能够有所帮助. CREATE OR REPLACE PROCEDURE P_STAT_SCORE ...
- treeTable的使用(ajax异步获取数据,动态渲染treeTable)
一.展示效果(treetable基本样式https://www.cnblogs.com/shuihanxiao/p/10413454.html) 二.html文件(若一个页面又多个treetable, ...
- 游标使用 和sp_executesql动态sql
/****** Script for SelectTopNRows command from SSMS ******/ declare @oid int declare @cid int declar ...
- mybatis 的sql语句及使用mybatis的动态sql mybatis防注入
由于看到写的比较详细的文档这里将之前的删掉了,只留下一些我认为能帮助理解的和关于动态sql及防注入的一些理解.文档链接 :mybatis官方文档介绍 <!-- 根据条件查询用户 --> ...
- sql server rdl report 如何用动态sql
我做rdl report 一般用存储过程,可是今天遇到个问题,需要用动态sql,rdl report数据集不能绑定字段 查了一下谷歌,解决如下: declare @CarrierList table ...
- sql 根据时间获取数据
获取当月数据 MONTH(时间字段)=MONTH(GETDATE()) and year(时间字段)=year(GETDATE()) 计算两个时间差了多少分钟 DATEDIFF(mi,'7:00',c ...
- Oracle SQL Lesson (1) - 使用SQL Select语句获取数据
第一节课: 启动数据库并且使用特定用户连接:su - oracle; 启动sqlplus并且使用sys连接:conn / as sysdba; 启动数据库:startup; 解锁用户:alter us ...
随机推荐
- 如何使用Dilworth定理
相关例题:NOIP 1999导弹拦截 遇到这题不会去网上搜Dilworth定理,太难受了,看不懂证明 但是,我知道怎么使用了,管那么多,会用就完事了 学习自这篇文章 -1.为什么我不想学证明这个定理 ...
- javaScript--进阶1--数据类型、操作符
一.JS基础知识背景 1.1 弱类型脚本语言 脚本语言是:弥补编译语言的不足而存在的,作为补充语言,不用编译,解析一行执行一行. 弱类型语言:简单理解定义一个变量,可以有多种数据类型.(var tem ...
- TestNG多线程测试-注解方式实现
用@Test(invocationCount = x,threadPoolSize = y)声明,invocationCount表示执行次数,threadPoolSize表示线程池大小. packag ...
- Tomcat服务器启动后访问localhost:8080显示404的原因
原因:在eclipse中关联了Tomcat服务器 重点来了,如果你是在eclipse中点击启动按钮启动的Tomcat 那么Tomcat不会默认部署它自己的测试项目(也就是大猫localhost:808 ...
- 将登录代码模块化,然后用add address接口来调用它,success!
登录模块,单独写成mylogin()方法,保存为modeltry119.py,然后接口的文件只写接口, 在post请求时,引用mylogin()返回的cookies就好了. requests.post ...
- 51NOD 1183编辑距离(动态规划)
>>点击进入原题测试<< 思路:这个题放在基础题,分值还是零分,好歹也给人家动态规划一点面子啊!刚开始写的想法是找到其最大公共字串,然后用两个字符串中最长字符串的长度减掉最大公 ...
- hammerjs & Swiper & touch & gesture
hammerjs https://hammerjs.github.io/getting-started/ http://hammerjs.github.io/recognizer-swipe/ Swi ...
- POJ 2142 TheBalance 模线性方程求解
题目大意: 就是将两种砝码左右摆放,能够在物品放置在天平上时保持平衡 很容易得到 ax + by = t的模线性方程 按题目要求,希望首先满足 |x| + |y| 最小 , 如果有多种情况,再满足所有 ...
- [luoguP2158] [SDOI2008]仪仗队(数论)
传送门 可以看出 (i, j) 能被看到,(i * k, j * k) 都会被挡住 暴力 所以 gcd(i, j) == 1 的话 ans ++ 那么可以枚举一半(中轴对称),求解答案,只能拿30分 ...
- 常州模拟赛d8t2 绘画
分析:考虑记录每个坐标上每个颜色出现了几次,并由此算出每个颜色在这个坐标上的贡献.答案肯定是原图的答案扣去矩形的答案,再加上那个矩形同种颜色的贡献,这里的答案指的是Σdis.我们先要记录每个颜色在各个 ...