`

PL/SQL开发笔记和小结(2)——PLSQL复合类型(转载)

 
阅读更多

*****************************************

PLSQL复合类型

*****************************************

记录类型record

record类型最常用,声明的时候可以加not null,但必须给初始值,如果record类型一致可以相互赋值,如果类型不同,里面的字段恰好相同,不能互相赋值。引用记录型变量的方法是记录变量名.基本类型变量名

  ―――――――――――――――――――――――――――――――――――――

  declare

       type t_first is record(

            id number(3),

            name varchar2(20)

       );

       v_first t_first;

  begin

     v_first.id:=1;

     v_first.name:='cheng';

     dbms_output.put_line(v_first.id);

     dbms_output.put_line(v_first.name);

  end;

  record类型变量间赋值

  declare

       type t_first is record(

            id number(3),

            name varchar2(20)

       );

       v_first t_first;

       v_second t_first;

  begin

       v_first.id:=1;

       v_first.name:='susu';

 

       v_second:=v_first;--相互赋值

 

       v_first.id:=2;

       v_first.name:='kettas';

       dbms_output.put_line(v_first.id);--2

       dbms_output.put_line(v_first.name);--kettas

       dbms_output.put_line(v_second.id);--1

       dbms_output.put_line(v_second.name);--susu

   end;

   ―――――――――――――――――――――――――――――――――――――

表类型变量table

语法如下:

    type 表类型 is table of 类型 index by binary_integer;

    表变量名表类型;

类型可以是前面的类型定义,index by binary_integer代表以符号整数为索引,这样访问表类型变量中的数据方法就是表变量名(索引符号整数)”table类型,相当于java中的Map容器,就是一个可变长的数组,key(符号整数索引)必须是整数,可以是负数value(类型)可以是标量,也可以是record类型。可以不按顺序赋值,但必须先赋值后使用。

1. 定义一维表类型变量

   ―――――――――――――――――――――――――――――――――――――

   declare

        type t_tb is table of varchar2(20) index by binary_integer;

        v_tb t_tb;

   begin

      v_tb(100):='hello';

      v_tb(98):='world';

      dbms_output.put_line(v_tb(100));

      dbms_output.put_line(v_tb(98));

   end;

   类型为record的表类型变量

   declare

        type t_rd is record(

id number,

name varchar2(20)

);

        type t_tb is table of t_rd index by binary_integer;

        v_tb2 t_tb;

   begin

        v_tb2(100).id:=1;

        v_tb2(100).name:='hello';

        dbms_output.put_line(v_tb2(100).id);

        dbms_output.put_line(v_tb2(100).name);

   end;

   ―――――――――――――――――――――――――――――――――――――

2. 定义多维表类型变量

该程序定义了名为tabletype1的多维表类型,相当于多维数组,table1是多维表类型变量,将数据表testtablerecordnumber60的记录提取出来存放在table1中并显示。

   ―――――――――――――――――――――――――――――――――――――

   declare

      type tabletype1 is table of testtable%rowtype index by binary_integer;

      table1 tabletype1;

   begin

       select * into table1(60) from testtable where recordnumber=60;

       dbms_output.put_line(table1(60).recordnumber||'  '||table1(60).currentdate);

   end;

   备注:在定义好的表类型变量里,可以使用countdeletefirstlastnextexistsprior等属性进行操作,使用方法为表变量名.属性,返回的是数字。

   declare

        type tabletype1 is table of varchar2(9) index by binary_integer;

        table1 tabletype1;

   begin

        table1(1):='成都市';

        table1(2):='北京市';

        table1(3):='青岛市';

        dbms_output.put_line('总记录数:'||table1.count);--3

        dbms_output.put_line('第一条记录:'||table1.first);--1

        dbms_output.put_line('最后条记录:'||table1.last);--3

        dbms_output.put_line('第二条的前一条记录:'||table1.prior(2));--1

        dbms_output.put_line('第二条的后一条记录:'||table1.next(2));--3

    end;

    ―――――――――――――――――――――――――――――――――――――

*****************************************

%type%rowtype

*****************************************

使用%type定义变量,为了让PL/SQL中变量的类型和数据表中的字段的数据类型一致,Oracle 9i提供了%type定义方法。这样当数据表的字段类型修改后,PL/SQL程序中相应变量的类型也自动修改。

    ―――――――――――――――――――――――――――――――――――――

    create table student(

       id number,

       name varchar2(20),

       age number(3,0)

    );

    insert into student(id,name,age) values(1,'susu',23);

    --查找一个字段的变量

    declare

       v_name student.name%type;

    begin

       select name into v_name from student where rownum=1;

       dbms_output.put_line(v_name);

    end;

    --查找多个字段的变量

    declare

        v_id student.id%type;

        v_name student.name%type;

        v_age student.age%type;

    begin

      select id,name,age into v_id,v_name,v_age from student where rownum=1;

      dbms_output.put_line(v_id||'  '||v_name||'  '||v_age);

    end;

    --查找一个类型的变量,推荐用*

    declare

       v_student student%rowtype;

    begin

       select * into v_student from student where rownum=1;

       dbms_output.put_line(v_student.id||'  '||v_student.name||'  '||v_student.age);

    end;

    --也可以按字段查找,但是字段顺序必须一样,不推荐这样做

    declare

       v_student student%rowtype;

    begin

     select id,name,age into v_student from student where rownum=1;

     dbms_output.put_line(v_student.id||'  '||v_student.name||'  '||v_student.age);

end;

 

    declare

       v_student student%rowtype;

    begin

     select id,name,age into v_student.id,v_student.name,v_student.age from student where id=1;

     --select * into v_student.id,v_student.name,v_student.age from student where id=1;

     dbms_output.put_line(v_student.id||'  '||v_student.name||'  '||v_student.age);

    end;

    ―――――――――――――――――――――――――――――――――――――

    备注:insertupdatedeleteselect都可以,create tabledrop table不行。DPLDML,和流程控制语句可以在pl/sql里用,但DDL语句不行。

    declare

       v_name student.name%type:='wang';

    begin

       insert into student(id,name,age) values(2,v_name,26);

    end;

 

    declare

       v_name student.name%type:='hexian';

    begin

       update student set name=v_name where id=1;

    end;

*****************************************

   PLSQL变量的可见空间

*****************************************

变量的作用域和可见性,变量的作用域为变量声明开始到当前语句块结束。当外部过程和内嵌过程定义了相同名字的变量的时候,在内嵌过程中如果直接写这个变量名是没有办法访问外部过程的变量的,可以通过给外部过程定义一个名字<<outername>>,通过outername变量名来访问外部过程的变量(待测试..)。

    ―――――――――――――――――――――――――――――――――――――

    declare

            v_i1 binary_integer:=1;

    begin

         declare

            v_i2 binary_integer:=2;

         begin

            dbms_output.put_line(v_i1);

            dbms_output.put_line(v_i2);

         end;

      dbms_output.put_line(v_i1);

    --dbms_output.put_line(v_i2);  解开后执行Oracle会提示必须说明标识符 'V_I2'”

    end;

 

转载自:http://www.blogjava.net/cheneyfree/archive/2008/07/19/216090.html 

分享到:
评论

相关推荐

    pl/sql快捷插件

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

    Oracle资料学习PL/SQL必备

    2. **数据类型**:PL/SQL支持多种数据类型,包括数值类型(如NUMBER)、字符串类型(如VARCHAR2、CHAR)、日期时间类型(如DATE)、布尔类型(BOOLEAN)以及复合数据类型(如记录和数组)。 3. **变量声明和赋值**...

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

    - **环境搭建与配置**:本书将介绍如何在不同的操作系统环境下安装并配置Oracle 11g数据库环境,以及如何设置PL/SQL Developer或其他开发工具来编写和测试PL/SQL代码。 - **基本语法与结构**:包括数据类型、变量...

    ORACLE PL/SQL从入门到精通

    ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括触发器、过程、函数、软件包、异常处理、游标、循环、分支、变量使用、数据库安装等关键知识点。 触发器是数据库中用来保证数据...

    pl/sql开发工具

    PL/SQL Developer是一款专为PL/SQL编程和Oracle数据库管理设计的强大开发工具。这款软件提供了全面的功能,使得数据库开发者和管理员能够高效地进行各种数据库操作,包括编写、调试、执行和管理PL/SQL代码,以及...

    PL/SQL Developer Evaluation Version 14.0.0.1961官方多语言版本(32位)

    PL/SQL Developer是一款专为Oracle数据库开发者设计的强大集成开发环境(IDE),由Allround Automations公司开发。这个“Evaluation Version 14.0.0.1961”是其官方发布的多语言版本,特别强调支持32位操作系统。这...

    PL/SQL Developer 10.0.5版本带sn亲测好用推荐

    PL/SQL Developer是一款由Allround Automations公司开发的专门针对Oracle数据库进行开发、管理和调试的集成开发环境(IDE)。在10.0.5这个版本中,它为开发者提供了高效且用户友好的界面,用于编写、测试和调试PL/...

    pl_sql.zip_fetch_pl/sql_pl_sql_plsql_plsql java

    PL/SQL,全称Procedural Language/Structured Query Language,是Oracle数据库提供的一个结合了SQL语句和过程式编程语言的编程环境。它主要用于管理和控制Oracle数据库,是Oracle数据库开发的核心工具之一。PL/SQL...

    PL/SQL Developer 11.0.2.1766绿色破解官方中文版下载

    PL/SQLDeveloper是一种集成的开发环境,专门用于开发、测试、调试和优化OraclePL/SQL存储程序单元,比如触发器等。PL/SQLDeveloper功能十分全面,大大缩短了程序员的开发周期。强大的PL/SQL编辑器,完善的Debugger...

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

    2. **变量和数据类型**:PL/SQL支持多种数据类型,包括数值型(NUMBER、BINARY_INTEGER、PLS_INTEGER)、字符型(VARCHAR2、CHAR)、日期型(DATE)、布尔型(BOOLEAN)以及复合数据类型如记录和数组。 3. **控制...

    PL/SQL Developer 客户端

    PL/SQL Developer是一个集成开发环境,专门开发面向Oracle数据库的应用。PL/SQL也是一种程序语言,叫做过程化SQL语言(Procedural Language/SQL)。PL/SQL是Oracle数据库对SQL语句的扩展。在普通SQL语句的使用上增加...

    PL/SQL Developer 13.0.6中文版32位64位+注册码

    PL/SQL Developer是一款专为Oracle数据库开发人员设计的集成开发环境(IDE),它极大地提高了编写、调试和管理PL/SQL代码的效率。13.0.6版本是该软件的一个更新迭代,旨在提供更好的性能和稳定性,同时也可能包含了...

    PL/SQL下载

    PL/SQL是Oracle数据库系统中的一个关键组成部分,它是一种结合了SQL语言与过程编程的语言,专为数据库管理和应用程序开发设计。PL/SQL全称为“Procedural Language/Structured Query Language”,它提供了丰富的控制...

    PLSQL.zip_oracl_oracle pl/sql ppt_pl sql ppt tutorial_pl/sql_pls

    "PLSQL.zip_oracl_oracle pl/sql ppt_pl sql ppt tutorial_pl/sql plsql.ppt"这个压缩包提供了学习PL/SQL的基础材料,通过"第一章 pl-sql介绍.ppt"开始你的学习之旅,逐步探索这个强大而灵活的数据库编程语言。

    plsql developer 11 中文手册.pdf

    PL/SQL Developer 11 是一款功能强大的集成开发环境(IDE),用于开发、调试和维护 Oracle 数据库下的 PL/SQL 程序。本手册旨在帮助用户快速上手使用 PL/SQL Developer 11,掌握其功能和特性。 1. 介绍 PL/SQL ...

    pl/sql12.0.2官方安装包完美汉化(含注册机)

    PL/SQL Developer是一款由Allround Automations公司开发的专门针对Oracle数据库进行开发、调试和管理的集成开发环境(IDE)。这个软件提供了强大的代码编辑、调试、数据库管理以及数据操作等功能,使得Oracle数据库...

    DBAtools for PL/SQL表空间管理器

    PL/SQL Developer是Oracle数据库当前最流行的开发工具之一,它在ORACLE数据库开发设计方面功能强大,使用方便,但是数据库管理方面一直比较欠缺。 DBATools For PL/SQL Developer 是一款PL/SQL Developer的辅助插件...

    Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(一)

     除了为读者提供编写sql语句和开发pl/sql块的方法外,本书还为应用开发人员提供了一些常用的pl/sql系统包。通过使用这些pl/sql系统包,应用开发人员可以开发出功能更强大的数据库应用程序。本书不仅适合sql和pl/sql...

    精通Oracle 10g SQL和PL/SQL

    本书是专门为oracle开发人员而提供的编程指南 通过学习本书 读者不仅可以掌握编写sql语句和pl/sql块的基础知识 而且还可以掌握sql高级特征 正则表达式 flashback查询 merge语句 sql:1999连接 和pl/sql高级特征 ...

    Oracle PL SQL程序设计 上 第五版(代码示例)

    《oracle pl/sql程序设计(第5版)》基于oracle数据库11g,从pl/sql编程、pl/sql程序结构、pl/sql程序数据、pl/sql中的sql、pl/sql应用构建、高级pl/sql主题6个方面详细系统地讨论了pl/sql以及如何有效地使用它。...

Global site tag (gtag.js) - Google Analytics