oracle学习 九 游标的使用(持续更)

为什么要使用?

笔者查阅了一些资料之后得到的结论是,

    关系型数据库是面向集合的,而游标是面向行的,游标可对取出来的集合(结果集)中每一行进行相同或不同的操作,还提供对基于游标位置而对表中数据进行删除或更新的能力,某些特     殊的查询操作也可以通过游标去完成,让你在查询暂时没办法的时候多了一种选择。游标的类型?    游标分为:    1、fetch  定义的游标名 into 游标变量    2、for 游标变量 in 游标名 loop   两种方式,其中for方式是隐式游标,可以对数据库后台进行打开关闭的操作,fetch是显示游标,需要操作者自行打开关闭,关于二者优劣网上说法不一,但是个人来看,还是for的方   式比较简便。游标语法:  有以下例子:  for:  
declare
--定义游标
cursor c_job
is
--查询的语句
select user_id,user_name from t_user_info;
--定义游标变量
c_row c_job%rowtype;
begin
  --使用游标变量在游标中进行检索
  for c_row in c_job loop
    dbms_output.put_line(c_row.user_id||‘-‘||c_row.user_name);
  --循环条件结束
  end loop;
end;

fetch:

DECLARE
  -- 定义游标.
  CURSOR c_test_main IS
    SELECT user_id, user_name FROM t_user_info;
  -- 保存游标数据的变量
  v_main_data c_test_main%ROWTYPE;
BEGIN
  -- 打开游标.
  OPEN c_test_main;
  LOOP
    -- 填充数据(主表).
    FETCH c_test_main INTO v_main_data;
    -- 假如没有检索到(主表)数据,结束循环处理
    Exit when c_test_main%NOTFOUND;

    dbms_output.put_line(v_main_data.user_id||‘-‘||v_main_data.user_name);

  END LOOP;
  -- 关闭游标
  CLOSE c_test_main;
END;

备注?

 1、 

dbms_output.put_line(‘输出内容‘);

 2、

游标变量名  表名%rowtype

游标变量名  游标名%rowtype

个人测试了以下,声明游标变量的两种方法中

游标变量名  游标名%rowtype  
这种方式运行的速度更快一点,它是再说这个变量是一行数据的实例,
类似于游标里的一行数据。而
游标变量名  表名%rowtype

这个方法是说这个变量是表中的一个实例,类似于表里的一行数据。
				
时间: 2024-11-06 13:33:53

oracle学习 九 游标的使用(持续更)的相关文章

oracle学习 七 拼接变量(持续更)

select count(KEYCODE) from STHSGDOC.ZJSJJL where ysrq=to_date(to_char(sysdate,'yyyy')||'/1','yyyy/MM/'); 查询当年一月份的数据,其中用到了to_char以及to_date, to_char的用法是吧字段转换为char类型,举个例子: to_char(sysdate, 'yyyy/mm/dd'); 相当于按照这个格式转化了系统的时间,结果就是'2003/07/09' . 那么to_date就是转

Oracle学习(九):创建和管理表

1.知识点:可以对照下面的录屏进行阅读 SQL> --创建表 SQL> create table test1 2 (tid number, 3 tname varchar2(20), 4 hidatedate date default sysdate); SQL> --使用as和子查询快速建表 SQL> --创建表:包含员工号 姓名 月薪 年薪 部门名称 SQL> create table empincome 2 as 3 select empno,ename,sal,sal

(七)Oracle学习笔记—— 游标

1.游标简介 游标用来处理从数据库中检索的多行记录(使用SELECT语句).利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录集. 为了处理SQL语句,Oracle将在内存中分配一个区域,这就是上下文区.这个区包含了已经处理完的行数.指向被分析语句的指针,整个区是查询(select)语句返回的数据行集.游标就是指向上下文区句柄或指针. 2.游标使用 2.1 定义一个游标 CURSOR cursor_name IS select_statement; 例如:把数据表中emp中部门号为20的员

linux命令学习笔记-持续更新版

shell 获取前一条命令是否执行成功 if [ $? -eq 0 ];then   echo "success" fi linux命令学习笔记-持续更新版

oracle学习入门系列之五 内存结构、数据库结构、进程

oracle学习入门系列之五 内存结构.数据库结构.进程 上篇蛤蟆简单描述了oracle公司的数据库产品.其他产品及oracle软件的一些特点.干货虽有但是真心是比较少的,这篇开始就是以干货为主,其中夹杂一些扯淡的事情了.蛤蟆一直也在想如何能生动的通过这干巴巴的文字来描述着世界级的软件,太理论大家都看不下去,太实践又缺乏深度.想想自己上大学那会,老师的讲课,无不枯燥乏味啊,满满的兴趣尽是消耗殆尽.所以不能仿效之,我们得走自己特色的路.以最易懂的形式.比喻等手段描述深奥的计算机知识.走起~ 开篇问

【Oracle学习笔记】

内容主要包含: (1)三种循环及其简化 (2)游标的使用 (3)异常处理 (4)存储过程 (5)存储函数 (6)触发器 (7)其他pl/sql操作 ---------------loop循环定义变量-------------------- declare cursor c1 is select * from emp;# rec emp%rowtype;# i numeber:=1; # v_count number;begin# select count(*) into v_count from

Oracle学习(十一):PL/SQL

1.知识点:可以对照下面的录屏进行阅读 PL/SQL程序结构 declare 说明部分 (变量说明,光标申明,例外说明 ] begin 语句序列 (DML语句]- exception 例外处理语句 End; / ------------------------------------------------------------------ --第一个PL/SQL程序:HelloWorld set serveroutput on --如果要在屏幕上输出信息,需要将serveroutput开关打

Oracle学习(三):单行函数

1.知识点:可以对照下面的录屏进行阅读 SQL> --字符函数 SQL> --字符串的转换 SQL> select lower('hellO WORld') 转小写,upper('hellO WORld') 转大写,initcap('hello world') 首字母大写 2 from dual; SQL> --substr(a,b) 从a中,第b位开始取,取右边所有的字符 SQL> select substr('Hello World',4) from dual; SQL&

oracle学习 第三章 常用的SQL*PLUS命令 ——02

今天接着昨天的RUN命令继续讲. 3.5 n(设置当前行)命令和A(PPEND)(附加)命令 设想,你输入了例3-10的查询语句 例 3-10 SQL> SELECT ename 2 FROM emp; 例 3-10 结果 看到以上输出时,您发现在SELECT子句中忘了job,sal.这时您又如何修改您的SELECT子句呢?首先您应该使用SQL*PLUS的L(LIST)命令来显示SQL缓冲中的内容. 例 3-11 SQL> L 例 3-11 结果 在例3-11显示的结果中,2后面的"