整理于 Oracle PL/SQL编程详解 – 古立 – 博客园 PL/SQL基础之DECLARE部分整理 PL/SQL块的结构 声明规范 标识符 数据类型 定义记录类型语法: 定义VARRY数据类型语法...: 使用%TYPE 使用%ROWTYPE 变量作用范围及可见性 因为SQL只能访问、操作数据库,却不能进行程序设计,而Oracle PL/SQL是一种高级数据库程序设计语言,该语言专门用于对ORACLE...注:在 PL/SQL中只能用 SQL语句中的 DML 部分,不能用 DDL 部分,如果要在PL/SQL中使用DDL(如CREATE table 等)的话,只能以动态的方式来使用。 1....DDL主要是用在定义或改变表的结构,数据类型,表之间的链接和约束等初始化工作上 PL/SQL块的结构 DECLARE --声明部分: 在此声明PL/SQL用到的变量,类型及游标,以及局部的存储过程和函数...声明规范 关于声明的规范,建议如下: 注: 通常情况不应让变量名与表中字段名一样 标识符 PL/SQL程序设计中的标识符定义与SQL 的标识符定义的要求相同。
PL/SQL是对SQL语言存储过程语言的扩展,是一种高级数据库程序设计语言,该语言专门用于在各种环境下对Oracle数据库进行访问。...除此之外,可以在Oracle数据库的某些客户端工具中,使用PL/SQL语言也是该语言的一个特点。PL/SQL可以向Java一样实现逻辑判断。条件循环和异常处理等。...PL/SQL块 pl/sql的基本单位是块。分为三部分,声明部分,执行部分,异常处理部分。其中执行部分时必须存在的,声明和异常处理可以没有。...--PL/SQL块的结构如下: DECLARE --声明部分: 在此声明PL/SQL用到的变量,类型及游标,以及局部的存储过程和函数 BEGIN -- 执行部分: 过程及SQL...在PL/SQL中,数组数据类型是VARRAY。
复合变量像标量变量一样也有数据类型,复合数据类型有记录(RECORD)、表(TABLE)、嵌套表(Nested TABLE)和数组(VARRAY)四种类型,其中,表、嵌套表和数组也称为集合,而集合类型(...可变数组(VARRAY)存储固定数量的元素(在运行中,可以改变元素数量),使用顺序数字作下标,可以定义等价的SQL类型,可以存储在数据库中。可以用SQL进行存储和检索,但比嵌套表缺乏灵活性。...如果处理单行单列的数据那么可以使用标量变量;如果处理单行多列数据那么可以使用PL/SQL记录;如果处理单列多行数据那么可以使用PL/SQL集合。...需要注意的是,该数据类型是PL/SQL数据类型,不能应用于表列。 下图是在PL/SQL中可以使用的预定义类型。 ?...图 3-1 PL/SQL中可以使用的预定义类型 数据类型的作用在于指明存储数值时需要占据的内存空间大小和进行运算的依据。
存储过程是保存可以接受或返回用户提供参数的SQL语句集合。在日常的使用中,经常会遇到复杂的业务逻辑和对数据库的操作,使用存储过程可以进行封装。...预定义异常:PL\SQL提供的系统异常 费预定义异常:用于处理与预定义异常无关的Oracle错误 自定义异常:处理Oracle错误之外的一些异常 使用方法: create or replace procedure...ZERO_DIVIDE 除数为0 SUBSCRIPT_BEYOND_COUNT 元素下表超过嵌套表或VARRAY的最大值 SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套类或VARRAY时,将下表指定为负数...VALUE_ERROR 赋值时,变量长度不足以容纳实际数据 LOGIN_DENIED PL\SQL应用连接到oracle时,提供了 不正确的用户名密码 NOT_LOGGED_ON PL\SQL应用程序在没有连接...oracle数据的情况下访问数据 PROGRAM_ERROR PL\SQL内部问题,可能需要重装数据字典 ROWTYPE_MISMATCH 主游标变量与PLSQL游标变量的返回类型不兼容 SELF_IS_NULL
DECLARE TYPE Foursome IS VARRAY(4) OF VARCHAR2(15); -- VARRAY type -- varray variable initialized.../SQL Composite Type Equivalent PL/SQL Composite Type Hash table Associative array Unordered table Associative.../SQL block or package No VARRAY (variable-size array) Specified Integer Always dense Null In PL/SQL block...if defined at schema level Nested table Unspecified Integer Starts dense, can become sparse Null In PL.../SQL block or package or at schema level Only if defined at schema level 文档 https://docs.oracle.com/
/sql developer debug 连接数据库后建立一个Test WINDOW 在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试 关于oracle存储过程的若干问题备忘...LOGIN_DENIED PL/SQL 应用程序连接到 oracle 数据库时,提供了不 正确的用户名或密码 NOT_LOGGED_ON...PL/SQL 应用程序在没有连接 oralce 数据库的情况下 访问数据 PROGRAM_ERROR PL/SQL 内部问题,可能需要重装数据字典& pl..../SQL 系统包 ROWTYPE_MISMATCH 宿主游标变量与 PL/SQL 游标变量的返回类型不兼容 SELF_IS_NULL...使用对象类型时,在 null 对象上调用对象方法 STORAGE_ERROR 运行 PL/SQL 时,超出内存空间 SYS_INVALID_ID
PL/SQL中提供了常用的三种集合联合数组、嵌套表、变长数组,而对于这几个集合类型中元素的操作,PL/SQL提供了相应的函数或过程来操 纵数组中的元素或下标。这些函数或过程称为集合方法。...对于使用DELETE方法操作的元素,PL/SQL会保留其占位符,后续可以重新利用。 ...TRIM 从集合的末尾删除一个(TRIM)或指定数量TRIM(n)的元素,PL/SQL对TRIM掉的元素不再保留占位符。 ...只有EXISTS能用于空集合,如果在空集合上调用其它方法,PL/SQL就会抛出异常COLLECTION_IS_NULL。...6 PL/SQL procedure successfully completed.
PL/SQL变长数组时PL/SQL集合数据类型中的一种,其使用方法与PL/SQL嵌套表大同小异,唯一的区别则是变长数组的元素的最大个数是有限 制的。...一、变长数组语法 TYPE type_name IS {VARRAY | VARYING ARRAY} (size_limit) OF -->type_name 用于指定varray类型名...用于指定元素的数据类型 varray_name TYPE_NAME; -->varray_name 用于定义...NULL值.所谓的空值指的是集合本身是空,不是针对它所拥有的元素 故在元素引用前需要对其进行初始化 三、变长数组示例 --1、声明变长数组,并输出其结果 scott@CNMMBO>...( 2 ) is : Jackson PL/SQL procedure successfully completed. --3、超出变长数组大小的情形 scott@CNMMBO> DECLARE
------------------------------------------- 4.通配符 _:一个下划线表示任意单个字符 %:表示任意多个字符(含0个字符) [abc]或[a-c]:属于字符集合中的任意一个字符
(3)当异常处理结束后,Oracle就将处理权交给调用者。结束PL/SQL块的运行。 Oracle将异常分为预定义异常、非预定义异常和自定义异常三种。...1、预定义异常(Predefined) 当PL/SQL应用程序违反了Oracle规定的限制时,就会隐含地触发一个内部异常,这就是预定义异常。...预定义异常用于处理常见的Oracle错误,对这种异常情况的处理,无需在程序中定义,由Oracle自动将其触发。它们全部放在PL/SQL自带的标准包中,这样程序员就无需再次定义了。...对嵌套或VARRAY索引使用了负数 ORA-06533 SUBSCRIPT_BEYOND_COUNT 对嵌套或VARRAY索引的引用大于集合中元素的个数 预定义异常的示例如下所示: SYS@lhrdb...使用预定义异常只能处理系统预定义的20多个Oracle错误,而当使用PL/SQL开发应用程序时,可能会遇到其它的一些Oracle错误。例如,在PL/SQL块中执行DML语句时,违反了约束规定等等。
的最大值 SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套表或 VARRAY 时,将下标指定为负数 VALUE_ERROR 赋值时,变量长度不足以容纳实际数据 LOGIN_DENIED PL/...SQL 应用程序连接到 oracle 数据库时,提供了不正确的用户名或密码 NOT_LOGGED_ON PL/SQL 应用程序在没有连接 oralce 数据库的情况下访问数据 PROGRAM_ERROR...PL/SQL 内部问题,可能需要重装数据字典& pl....运行 PL/SQL 时,超出内存空间 SYS_INVALID_ID 无效的 ROWID 字符串 TIMEOUT_ON_RESOURCE Oracle 在等待资源时超时 基本语法 1....用pl/sql developer debug 连接数据库后建立一个Test WINDOW,在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试 关于oracle存储过程的若干问题备忘 1
任何ORACLE错误(报告为ORA-xxxxx形式的Oracle错误号)、PL/SQL运行错误或用户定义条件(不一写是错误),都可以。...ORA-6531 Collection-is-null 试图将Exists 以外的集合(collection)方法应用于一个null pl/sql 表上或varray上 ORA-6532 Subscript-outside-limit...对嵌套或varray索引得引用超出声明范围以外 ORA-6533 Subscript-beyond-count 对嵌套或varray 索引得引用大于集合中元素的个数..../SQL块的ORACLE错误或由PL/SQL代码的某操作引起的错误,如除数为零或内存溢出的情况。...用户自定义异常由开发者显示定义,在PL/SQL块中传递信息以控制对于应用的错误处理。 每当PL/SQL违背了ORACLE原则或超越了系统依赖的原则就会隐式的产生内部异常。
结果 intersect:只返回同时出现在两个select语句中的行 十三、 PL/SQL declare begin <executable...emp.emono%type; varray_empno varray_empno_type; begin varray_empno:=varray_empno_type(7369.7499);...8、 集合的方法 count:集合中的元素个数 delete:删除集合中所有元素 delete(x):删除下标为x的元素 delete(x,y):删除下标从x到y的元素 extend:在集合末尾添加一个元素...extend(x):在集合末尾添加x个元素 extend(x,n):在集合末尾添加n个x的副本 first:返回第一个元素的下标号,对于varray始终返回1 last:返回最后一个元素的下标号...19、 异常处理 a、 异常的抛出方式 pl/sql运行时 raise exception_name 调用raise_application_erroe b、 exception when
数组在各种编程语言中都是很重要的数据结构实现,在oracle中也有自己的一席之地。自己简单做了几个实验,发现很多东西还是眼高手低,真实去做的时候,里面还是有不少的细节的。...长度为10 SQL> create type varray_type as varray(10) of number(10); 2 / Type created....SQL> drop type varray_type; Type dropped....SQL> create type varray_type is varray(10) of number(10) 2 / Type created....PLS-00729: only widening of the collection element type is allowed ORA-06550: line 0, column 0: PL/SQL
PL/SQL是Oracle数据库对SQL语句的扩展。...2、 PL/SQL类别:数据库引擎、工具引擎(嵌入到其他语言如:C、JAVA)。 3、 PL/SQL包括:编程结构、语法和逻辑机制,工具引擎还增加了支持(如ORACLE Forms)的句法。...2、客户端 可以在客服端执行本地的PL/SQL,或通过向服务器发送SQL命令或激活服务器端来运行PL/SQL程序。 3、支持过程化 可嵌入SQL语句,及使用各种类型的条件分支语句和循环语句。...2、 运行的方式: PL/SQL可在SQL*PLUS、高级语言、 ORACLE开发工具中使用(如:SQL Developer或Procedure Builder等。...3、运行的过程: PL/SQL程序的运行是通过Oracle中的一个引擎来进行的。这个引擎可能在Oracle服务器端,也可能在 Oracle 客户端。
pl/sql中“=”表示比较,“:=”表示赋值。
有关集合类型的描述请参考: PL/SQL 联合数组与嵌套表 PL/SQL 变长数组 PL/SQL --> PL/SQL记录 一、联合数组的赋值 联合数组的不需要初始化,直接赋值即可。...a、如果下标索引不存在或无法转换成正确的数据类型,PL/SQL就会抛出预定义异常VALUE_ERROR。 通常,下标是一个整数。...b、如果所给下标索引指向了一个未初始化的元素时,PL/SQL就会抛出SUBSCRIPT_BEYOND_COUNT异常。 ...c、如果集合被自动初始化为空值并且程序引用了其中的一个元素,PL/SQL会抛出COLLECTION_IS_NULL异常。...10、注意理解复合类型之间(嵌套表和变长数组中嵌有PL/SQL记录)的变量元素间的传递以及集合方法BULK COLLECT INTO,LAST,EXTEND等。
--===================== -- PL/SQL --> 语言基础 --===================== PL/SQL是过程化的SQL语言,是ORACLE对SQL语言的扩展.../SQL的语言优点 支持SQL 高生成率,性能好 可移植性 与Oracle集成 二、PL/SQL的语法要素 PL/SQL语法要素包括字符集、标识符、文本、分隔符、注释等。.../sql记录,pl/sql表,嵌套表,varray四种复合类型 --定义PL/SQL记录 declare type emp_record_type is record( name emp.ename...CONNECT BY PRIOR) 有关PL/SQL请参考 PL/SQL --> 语言基础 PL/SQL --> 流程控制 PL/SQL --> 存储过程 PL/SQL --> 函数 PL/SQL...--> 游标 PL/SQL -->隐式游标(SQL%FOUND) PL/SQL --> 异常处理(Exception) PL/SQL --> PL/SQL记录 PL/SQL --> 包的创建与管理 PL
游标可以理解为是PL/SQL中的结果集,我们通过游标可以提取结果集中的每行记录。 ?...的最大值 SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套表或 VARRAY 时,将下标指定为负数 VALUE_ERROR 赋值时,变量长度不足以容纳实际数据 LOGIN_DENIED PL/...SQL 应用程序连接到 oracle 数据库时,提供了不正确的用户名或密码 NOT_LOGGED_ON PL/SQL 应用程序在没有连接 oralce 数据库的情况下访问数据 PROGRAM_ERROR...PL/SQL 内部问题,可能需要重装数据字典& pl....运行 PL/SQL 时,超出内存空间 SYS_INVALID_ID 无效的 ROWID 字符串 TIMEOUT_ON_RESOURCE Oracle 在等待资源时超时 范例1:写出被0除的异常的plsql
--在hibinate 中如何传递参数给 存储过程 ---新建一个存储要存储集合id 的临时表 -- Create table create table MBRC_OLTPORTID ( ID...CREATE TYPE AOBJECT AS OBJECT( a NUMBER(18) ) ------定义一个List数据库对象 CREATE TYPE ALIST AS VARRAY... -1)) + 2, 'iw') from dual; ------oracle...what参数是将被执行的PL/SQL代码块。 next_date参数指识何时将运行这个工作。 interval参数何时这个工作将被重执行。 ...no_parse参数指示此工作在提交时或执行时是否应进行语法分析——TRUE 指示此PL/SQL代码在它第一次执行时应进行语法分析, 而FALSE指示本PL/SQL代码应立即进行语法分析
领取专属 10元无门槛券
手把手带您无忧上云