OraclePL编程语言的优点介绍

OraclePL/SQL通俗的讲就是过程语言(Procedural Language)和结构化查询的相关语言(SQL)相结合而演变成的编程语言,OraclePL/SQL其实就是对SQL 的扩展,它支持多种数据类型,如大对象和集合类型可以使用条件和循环等控制结构。

可以创建存储过程,触发器和程序包,给SQL 语句的执行添加程序逻辑!他与Oracle服务器

 

和Oracle工具紧密集成,具备可移植,灵活性和安全性。

 

PL/SQL 的优点

 

支持 SQL

 

数据操纵命令

 

事务控制命令

 

游标控制

 

SQL 函数和 SQL 运算符

 

支持面向对象编程 (OOP)

 

可移植性

 

可运行在任何操作系统和平台上的Oralce 数据库。

 

更佳的性能

 

与 SQL 紧密集成,简化数据处理

 

支持所有 SQL 数据类型

 

支持 NULL 值

 

支持 %TYPE 和 %ROWTYPE 属性类型

 

安全性

 

可以通过存储过程限制用户对数据的访问。

 

PL/SQL 的体系结构

 

PL/SQL引擎驻留在Oracle服务器中,该引擎接受PL/SQL块,并且对起

 

进行编译执行!#p#

PL/SQL 块简介

 

OraclePL/SQL块是构成程序的基本单位,每一个块都包含有PL/SQL和SQL语句,典型的PL/SQL代码块包含如下结构:

 

(1).声明部分

 

(2)可执行部分

 

(3)异常处理

 

语法结构如下:

 

[DECLARE

 

declarations]—声明部分

 

BEGIN

 

executable statements—可执行部分

 

[EXCEPTION –异常处理

 

 

  1. handlers]  
  2. END;  

 

 

代码示例:

 

DECLARE

 

qty_on_hand NUMBER(5); –程序声明部分,定义变量,游标和自定义常量

 

 

  1. BEGIN   
  2. SELECT quantity INTO qty_on_hand -  
  3. FROM Products -  
  4. WHERE product = '芭比娃娃' -  
  5. FOR UPDATE OF quantity; -  
  6. IF qty_on_hand > 0 THEN -  
  7. UPDATE Products SET quantityquantity = quantity + 1 - 

 

 

WHERE product = ‘芭比娃娃’; 程序执行部分

 

 

  1. INSERT INTO purchase_record -  
  2. VALUES ('已购买芭比娃娃', SYSDATE); -  
  3. END IF; -  
  4. COMMIT; - 

 

 

EXCEPTION /* 异常处理语句 * / ———————–异常处理

 

 

  1. WHEN OTHERS THEN -  
  2. DBMS_OUTPUT.PUT_LINE('出错:'|| SQLERRM); -  
  3. END; 

 

 

变量和常量

OraclePL/SQL 块中可以使用变量和常量

 

在声明部分声明,使用前必须先声明

 

声明时必须指定数据类型,每行声明一个标识符

 

在可执行部分的 SQL 语句和过程语句中使用

 

声明变量和常量的语法

 

 

  1. identifier [CONSTANT] datatype [NOT NULL]   
  2. [:= | DEFAULT expr];  

 

 

给变量赋值有两种方法

 

使用赋值语句 :=

 

使用 select into 语句

 

代码示例:

 

 

  1. DECLARE  
  2. icode VARCHAR2(6);   
  3. p_catg VARCHAR2(20);   
  4. p_rate NUMBER;   
  5. c_rate CONSTANT NUMBER :0.10;   
  6. BEGIN  
  7. ...  
  8. icode :'i205';   
  9. SELECT p_category, itemrate * c_rate  
  10. INTO p_catg, p_rate  
  11. FROM itemfile WHERE itemcode = icode;   
  12. ...  
  13. END; 

 

 

数据类型

OraclePL/SQL支持的内置数据类型有如下几种:

 

如图:

 

标量类型

 

数字

 

字符

 

CHAR

 

VARCHAR2

 

LONG

 

RAW

 

LONG RAW

 

结构如图:

 

日期时间类型

 

日期时间类型

 

存储日期和时间数据

 

常用的两种日期时间类型

 

DATE

 

TIMESTAMP

 

布尔类型

此类别只有一种类型,即BOOLEAN类型

 

用于存储逻辑值(TRUE、FALSE和NULL)

 

不能向数据库中插入BOOLEAN数据

 

不能将列值保存到BOOLEAN变量中

 

只能对BOOLEAN变量执行逻辑操作

 

如图:

LOB类型

 

用于存储大文本、图像、视频剪辑和声音剪辑等非结构化数据。

 

LOB数据类型可存储*** 4GB的数据。

 

LOB 类型包括:

 

BLOB 将大型二进制对象存储在数据库中

 

CLOB 将大型字符数据存储在数据库中

 

NCLOB 存储大型UNICODE字符数据

 

BFILE 将大型二进制对象存储在操作系统文件中

 

LOB 类型的数据库列仅存储定位符,该定位符指向大型对象的存储位置

DBMS_LOB程序包用于操纵 LOB 数据

 

代码示例:

 

 

  1. SET SERVEROUTPUT ON  
  2. DECLARE  
  3. clob_var CLOB;   
  4. amount INTEGER;   
  5. offset INTEGER;   
  6. output_var VARCHAR2(100);   
  7. BEGIN  
  8. SELECT chapter_text INTO clob_var   
  9. FROM my_book_text  
  10. WHERE chapter_id=5;  

 

 

amount := 24; — 要读取的字符数

 

offset := 1; — 起始位置

 

 

  1. DBMS_LOB.READ(clob_var,amount,offset,output_var);   
  2. DBMS_OUTPUT.PUT_LINE(output_var);   
  3. END;   

 

 

 文章出自:http://database.csdn.net/page/08155ea6-cb32-4167-ad08-022873597ded

【编辑推荐】

  1. 探讨Oracle中rownum的用法
  2. Oracle细粒度的访问控制的基本工作方式
  3. 浅析:Oracle jdbc分页效率的测试
  4. Oracle数据库的异构服务原理描述
  5. Oracle 10g数据库的相关内容描述

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/245824.html<

(0)
管理的头像管理
上一篇2025-04-26 09:01
下一篇 2025-04-26 09:02

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注