- 浏览: 127206 次
- 性别:
- 来自: 苏州
文章分类
最新评论
-
miniduan:
i here by provide one that work ...
python 文件插入第一行 -
miniduan:
验证了一下,不好用啊:import fileinput, os ...
python 文件插入第一行
游标是构建在L/SQL中用来查询数据库、获取记录集合(结果集)的指针,它使开发人员能够一次访问一行结果集。为了处理SQL语句,Oracle将在内存中分配一个区域,这就是上下文区。这个区包含了已经处理完的行数、指向被分析语句的指针,整个区是查询语句返回的数据行集。游标就是指向上下文区句柄或指针。两种游标:
- 显示游标:显示游标被用于处理返回多行数据的SELECT语句,游标名通过CURSOR….IS 语句显示地赋给SELECT 语句。在PL/SQL中处理显示游标所必需的四个步骤:
- 声明游标:
CURSOR cursor_name IS select_statement
- 打开游标:
OPEN cursor_name
- 取得结果放入PL/SQL变量中:
FETCH cursor_name INTO list_of_variables; FETCH cursor_name INTO PL/SQL_record;
- 关闭游标:
CLOSE cursor_name
注意:在声明游标时,select_statement不能包含INTO子句。当使用显示游标时,INTO子句是FETCH语句的一部分。
- 声明游标:
- 隐式游标:所有的隐式游标都被假设为只返回一条记录。使用隐式游标时,用户无需进行声明、打开及关闭。PL/SQL隐含地打开、处理,然后关掉游标。
四种常用的游标例子:
- FOR循环游标:
declare -- 类型定义 cursor my_cursor is select empno,ename,job,sal from emp where job = 'MANAGER'; begin -- for 循环 for cursor_record in my_cursor loop dbms_output.put_line(cursor_record.empno||'-'||cursor_record.ename ||'-'||cursor_record.job||'-'||cursor_record.sal); end loop; end;
- Fecth游标:
/* * Fetch游标 */ declare -- 类型定义 cursor my_cursor is select empno, ename, job, sal from emp where job = 'MANAGER'; -- 定义一个游标变量 l_cursor my_cursor%rowtype; begin -- 打开游标 open my_cursor; -- loop循环 loop -- 提取一行数据到l_cursor变量中 fetch my_cursor into l_cursor; exit when my_cursor%notfound; dbms_output.put_line(l_cursor.empno||'-'||l_cursor.ename|| '-'||l_cursor.job||'-'||l_cursor.sal||'-'||my_cursor%rowcount); end loop; -- 关闭游标 close my_cursor; end;
游标的4种属性:- %notfound fetch是否提到数据 没有true 提到false
- %found fetch是否提到数据 有true 没提到false
- %rowcount 已经取出的记录的条数
- %isopen 布尔值 游标是否打开
- 参数游标:
/* * 参数游标 */ declare -- 获得部门 cursor my_cursor1 is select deptno from dept; -- 定义游标参数,只能指定类型,不能指定长度 cursor my_cursor2(no number, pjob varchar2) is select emp.* from emp where deptno = no and job = pjob; begin for cursor_record1 in my_cursor1 loop -- 参数在游标中使用 for cursor_record2 in my_cursor2(cursor_record1.deptno, 'MANAGER') loop dbms_output.put_line(cursor_record2.deptno || '-' || cursor_record2.ename); end loop; end loop; end;
- 引用游标/动态游标:
/* * 引用游标/动态游标 */ declare -- 定义一个弱类型的ref cursor type weakly_cursor is ref cursor; -- 定义一个强类型的ref cursor type strongly_cursor is ref cursor return dept%rowtype; -- 定义ref cursor类型的变量 w_cursor weakly_cursor; s_cursor strongly_cursor; -- 定义记录 emp_record emp%rowtype; dept_record dept%rowtype; begin dbms_output.put_line('输出员工'); open w_cursor for select * from emp; loop fetch w_cursor into emp_record; exit when w_cursor%notfound; dbms_output.put_line(emp_record.ename); end loop; close w_cursor; dbms_output.put_line('输出部门'); open s_cursor for select * from dept; loop fetch s_cursor into dept_record; exit when s_cursor%notfound; dbms_output.put_line(dept_record.dname); end loop; close s_cursor; end;
发表评论
-
mysql 5.7.14-winx64 安装
2016-08-22 22:40 507下载,解压 bin目录增加入path变量 管理员身份启动 ... -
toad 未安装oracle客户端 配置
2013-11-15 11:08 15551. 下载toad软件和oracle的instantcli ... -
linux oracle 12514错误解决办法
2013-07-30 17:34 1880解决方法: 1. 打开<OracleHome> ... -
ora-00054:resource busy
2013-07-24 16:26 883当某个数据库用户在数据库中插入、更新、删除一个表的数据,或 ... -
Oracle 启动
2013-07-03 09:57 708$ su - oracle $ sqlplus / as ... -
sqlserver字符串拆分(split)方法汇总
2012-05-15 13:58 1003--方法0:动态SQL法 declare @s varcha ... -
sql server 索引简介
2012-04-01 17:29 933什么是索引 拿汉语字典的目录页(索引)打比方 ... -
T-SQL之SET ANSI_NULLS
2012-03-21 14:20 1034当 SET ANSI_NULLS 为 ON 时 ... -
sqlserver 获得外键关联表名
2012-03-14 18:59 1731获取表修改时间:SELECT modify_date FR ... -
sql server 查询表名,列名等
2012-03-14 18:23 4513--1:获取当前数据库中的所有用户表 select Name ... -
连接mysql和 建索引花费
2012-02-07 10:23 952mysql -h192.168.0.150 -uroot -p ... -
查询乱码和按月查询
2012-01-04 15:29 928SET character_set_connection=ut ... -
PL/SQL 控制语句
2011-12-01 11:04 876条件语句: if...then...else语句: dec ... -
Oracle 集合 方法
2011-11-30 11:22 774The COUNT Method: 用于计算 associa ... -
oracle 集合
2011-11-29 17:07 651记录(Record): 由单行多 ... -
oracle PL/SQL 标量数据类型
2011-11-28 18:17 1212字符数据类型: 类型名称 描述 char ... -
oracle 情景查询
2011-11-25 14:26 756decode()函数: 类似于if ... then ... ... -
Oralce 层次查询
2011-11-25 14:00 697初始化数据库,创建表和导入数据:create tab ... -
Oracle 时间和字符串的装换
2011-11-24 16:33 937使用to_char()函数可以完成从日期数据到字符串的准换过 ... -
Pl/SQL Developer 常用技巧
2011-11-24 10:55 679PL/SQL Developer记住登陆 ...
相关推荐
Oracle 游标概述 Oracle 游标是 Oracle 数据库中的一种重要概念,用于查询数据库,获取记录集合(结果集)的指针。游标可以看作是一个临时表,你可以对其每一行的数据进行任意的操作。本文将对 Oracle 游标的概念、...
下面,我们将深入探讨Oracle游标的使用示例及其相关的知识点。 首先,游标的基本概念是它提供了一种方式来跟踪并控制SQL查询的结果集。在Oracle中,游标有四种状态:未打开、已打开、正在提取和已关闭。以下是一个...
### Oracle游标使用详解 #### 一、Oracle游标简介 在Oracle数据库中,游标是一种重要的机制,用于处理查询结果集。它允许用户通过PL/SQL编程语言逐行访问和处理查询返回的数据记录。游标可以是显式定义的(即在...
总之,Oracle游标提供了处理查询结果的强大工具,使开发者能够灵活地在PL/SQL中操作数据。无论是隐式还是显式游标,都极大地增强了对数据库的交互能力,使得程序能根据查询结果进行适当的操作。理解并熟练运用游标是...
Oracle游标是数据库编程中非常重要的一个概念,主要用于处理SQL查询的结果集。游标允许我们按行处理数据,逐条读取结果集,而不仅仅是一次性获取所有数据。在Oracle数据库中,游标对于复杂的事务处理、动态SQL以及...
Oracle 游标使用方法及语法大全 Oracle 游标是 PL/SQL 程序中的一种重要组件,用于处理查询结果集。游标可以分为隐式游标和显式游标两种,隐式游标由 PL/SQL 管理,隐式游标打开时查询开始,查询结束时隐式游标自动...
### Oracle游标使用及实例详解 #### 一、Oracle游标概述 在Oracle数据库中,游标(Cursor)是一种用于处理SQL查询结果集的方式。它允许用户逐行地读取和处理查询结果,这对于需要对每一行数据进行特定操作的情况非常...
### Oracle游标使用详解 #### 一、游标概述 游标是Oracle数据库中用于处理查询结果集的强大工具,尤其适用于需要逐行处理查询结果的情况。在Oracle中,游标可以分为两类:**显式游标**和**隐式游标**。 1. **隐式...
Oracle游标是数据库编程中非常重要的一个概念,它允许开发者逐行处理查询结果集,而不仅仅是一次性处理所有数据。在Oracle中,游标分为隐式游标和显式游标。 **一、游标简介** 游标的核心功能是提供一种方式来遍历...
根据提供的标题、描述以及部分代码内容,我们可以详细探讨Oracle游标的使用方法,特别是明确游标(Explicit Cursor)和隐式游标(Implicit Cursor)的区别及其具体应用方式。 ### Oracle游标简介 在Oracle数据库中...
通过本篇Oracle游标的使用大全,我们可以了解到Oracle数据库游标的类型、属性以及如何在PL/SQL中实现对数据集的逐行处理。这不仅有助于提升程序员的编程技能,也能使他们更深入地理解PL/SQL与Oracle数据库之间的交互...
### Oracle游标使用详解 #### 一、Oracle游标简介 在Oracle数据库中,游标是一种用于处理查询结果集的强大工具。它允许用户通过逐行访问数据来执行复杂的操作,如更新、删除或插入记录等。游标可以分为显式游标和...
Oracle游标是数据库管理系统中的一种重要机制,它允许程序员逐行处理查询结果集,而不仅仅是一次性获取所有数据。游标类似于C语言中的指针,能够灵活、高效地处理多条记录,尤其在需要循环处理或者根据当前行数据做...
根据提供的文件信息,我们可以归纳出以下Oracle游标的使用方法及相关知识点: ### 一、游标的基本概念 在Oracle数据库中,游标是一种重要的机制,它允许用户从查询结果集中逐行检索数据。游标可以分为两种类型:**...
首先,让我们来理解Oracle游标。游标是数据库系统提供的一种机制,允许用户在结果集上进行迭代,一次处理一行数据。在PL/SQL中,游标用于检索SQL查询返回的结果集,并按需逐行处理。以下是一个简单的游标使用示例: ...
### Oracle游标优化 在Oracle数据库管理中,游标是一种重要的机制,用于处理查询结果集。游标可以被看作是存储查询结果的一种临时区域,它允许用户通过循环逐行处理这些结果。游标不仅可以提高应用程序的灵活性,还...