PL/SQL

  • PL/SQL是Oracle在关系数据库结构化查询语言SQL基础上扩展得到的一种过程化查询语言。
  • SQL与编程语言之间的不同在于,SQL没有变量,SQL没有流程控制(分支,循环)。而PL/SQL是结构化的和过程化的结合体,而且最为重要的是,在用户执行多条SQL语句时,每条SQL语句都是逐一的发送给数据库,而PL/SQL可以一次性将多条SQL语句一起发送给数据库,减少网络流量

SQL执行

PL/SQL执行

  • 匿名Pl/SQL块
    • – 动态构造,只能执行一次
    • 一次性完成,没有名字
  • 存储过程,函数,触发器
    • 给它一个名字,保存到数据库,可以反复使用,调用.
    • – 存储在数据库中编译过的代码,可以反复执行。

PL/SQL语法结构

语法:

DECLARE

-- 声明部分,例如:定义变量、常量、游标。

BEGIN

-- 程序编写、SQL语句

EXECTPION

-- 处理异常

END ;

/

说明:

声明部分(DECLARE)

包含变量定义、用户定义的PL/SQL类型、游标、引用的函数或过程;

执行部分(BEGIN)

包含变量赋值、对象初始化、条件结构、迭代结构、嵌套的PL/SQL匿名块,或是对局部或存储PL/SQL命名块的调用;

异常部分(EXCEPTION)

包含错误处理语句,该语句可以像执行部分一样使用所有项;

结束部分(END)

程序执行到END表示结束,分号用于结束匿名块,而正斜杠(/)执行块程序;

默认情况下系统输出显示被关闭的,需要设定 SET SERVEROUTPUT ON

匿名Pl/SQL块

– 动态构造,只能执行一次

一次性完成,没有名字

范例

编写不做任何工作的PL/SQL块

BEGIN

NULL ;

END ;

/

最简单的循环PL/SQL匿名块,null表示什么也没干

BEGIN

for i in 1..10 loop

null;

end loop;

END;

/

编写HELLO WORD

SQL> BEGIN

2 DBMS_OUTPUT.put_line('HELLO,WENDY');

3 END;

4 /

HELLO,WENDY

PL/SQL procedure successfully completed.

匿名PL/SQL块,循环显示2遍HELLOW,WENDY

BEGIN

For I in 1..2 loop

DBMS_OUTPUT.put_line('HELLO,WENDY');

End loop;

END;

/

匿名PL/SQL块,循环插入数据

SQL> insert into t select rownum,'x' from dba_objects where rownum<101;

能用SQL解决的就不要用PL/SQL

PL/SQL会消耗资源,效率很低

BEGIN

for i in 1..100 loop

insert into t values(i,'w');

end loop;

END;

/

编写一个简单的PL/SQL程序

:= 为变量赋值

DECLARE

v_num NUMBER ;    -- 定义一个变量v_num

BEGIN

v_num := 30 ;         -- 设置v_num的内容

DBMS_OUTPUT.put_line('V_NUM变量的内容是:' || v_num) ;

END ;

/

编写PL/SQL块,输入一个雇员编号,而后取得指定的雇员姓名

DECLARE

v_eno    NUMBER ;

v_ename    VARCHAR2(10) ;

BEGIN

v_eno := &empno ;        -- 由键盘输入雇员编号

SELECT ename INTO v_ename FROM emp WHERE empno=v_eno ;

DBMS_OUTPUT.put_line('编号为:' || v_eno || '雇员的名字为:'|| v_ename) ;

END ;

/

PL/SQL编程基础(一):PL/SQL语法简介(匿名PL/SQL块)的更多相关文章

  1. 【PL/SQL编程基础】

    [PL/SQL编程基础]语法: declare 声明部分,例如定义变量.常量.游标 begin 程序编写,SQL语句 exception 处理异常 end: / 正斜杠表示执行程序快范例 -- Cre ...

  2. Oracle数据库编程:PL/SQL编程基础

    2.PL/SQL编程基础: PL/SQL块:        declare        定义部分        begin        执行部分        exception        异 ...

  3. PL/SQL编程基础(三):数据类型划分

    数据类型划分 在Oracle之中所提供的数据类型,一共分为四类: 标量类型(SCALAR,或称基本数据类型) 用于保存单个值,例如:字符串.数字.日期.布尔: 标量类型只是作为单一类型的数据存在,有的 ...

  4. PL/SQL编程基础(五):异常处理(EXCEPTION)

    异常处理 异常产生所带来的问题: 使用EXCEPTION程序块进行异常处理: 实现用户自定义异常. 使用异常可以保证在程序中出现运行时异常时程序可以正常的执行完毕: 用户可以使用自定义异常进行操作. ...

  5. PL/SQL编程基础——PL/SQL简介

    课程教师:李兴华 课程学习者:阳光罗诺 日期:2018-07-28 知识点: 1. 了解PL/SQL的主要特点 2. 掌握PL/SQL块的基本结构 PL/SQL PL/SQL是Oracle在关系数据库 ...

  6. Oracle Pl/SQL编程基础

    Pl/SQL简介 提高应用程序的运行性能, 提供模块化的程序设计, 自定义标示符, 具有过程语言控制结构, 良好的兼容性, 处理运行错误. Pl/SQL语言基础 sql是关系数据库的基本操作语言. s ...

  7. ROS Learning-032 (提高篇-010 Launch)Launch 深入研究 --- (启动文件编程)ROS 的 XML语法简介

    ROS 提高篇 之 Launch 深入研究 - 01 - 启动文件的编程 - ROS 的 XML语法简介 我使用的虚拟机软件:VMware Workstation 11 使用的Ubuntu系统:Ubu ...

  8. PL/SQL编程基础

    范例:编写不做任何工作的PL/SQL块 BEGIN NULL ; END ; /   范例:编写一个简单的PL/SQL程序 DECLARE v_num NUMBER ; -- 定义一个变量v_num ...

  9. PL/SQL编程基础(四):程序控制(IF,CASE,FOR,LOOP,WHILE LOOP,EXIT,CONTINUE)

    程序控制 程序结构有分支结构与循环结构: 分支结构语法:IF.CASE: 循环结构:FOR.WHILE LOOP:先执行再判断,至少执行一次: WHILE LOOP:先判断再执行,如果不满足条件,就不 ...

随机推荐

  1. find_circ 识别circRNA 的原理

    find_circ 通过识别junction reads 来预测circRNA 和参考基因组比对完之后,首先剔除和基因组完全比对的reads,保留没比对上的reads, 这部分reads 直接比是比对 ...

  2. Mysql中Innodb大量插入数据时SQL语句的优化

    innodb优化后,29小时入库1300万条数据 参考:http://blog.51yip.com/mysql/1369.html 对于Myisam类型的表,可以通过以下方式快速的导入大量的数据: A ...

  3. RAC DBCA 找不到共享磁盘

    (一)  前言:  通过vmware workstation 走iscsi协议.安装RAC 集群架构,DBCA 时不能识别ASM 共享存储(按理来说这一版都是权限的问题).同一时候,本想通过RMAN ...

  4. Python学习笔记(二)——高级特性

    知识点 切片 切片 取一个list或tuple的部分元素. 原理:调用__getitem__,__setitem__,__delitem__和slice函数. 根据官方的帮助文档(https://do ...

  5. mybatis由浅入深day02_7.4mybatis整合ehcache_7.5二级缓存应用场景_7.6二级缓存局限性

    7.4 mybatis整合ehcache EhCache 是一个纯Java的进程内缓存框架,是一种广泛使用的开源Java分布式缓存,具有快速.精干等特点,是Hibernate中默认的CacheProv ...

  6. Mysql综合案例

    Mysql综合案例 考核要点:创建数据表.单表查询.多表查询 已知,有一个学生表student和一个分数表score,请按要求对这两个表进行操作.student表和score分数表的表结构分别如表1- ...

  7. Int 型数值存储

    1. Int 在计算机中占 4 Byte, 共 32 位, 最大正数为 2147483647, 最小负数为 -2147483648 2. 正数存储在计算机中的形式为原码,最大正数的十六进制形式为 0X ...

  8. GeoServer安装说明-OpenSpirit

    一.安装步骤 1.安装JDK: 2.安装Tomcat:(本测试过程使用JspStudy,需要进行端口设置,并指定Web目录,如:D:\JspStudy\tomcat\webapps) 3.拷贝geos ...

  9. laravel 强大的关联模型

    内容比较多,不总结了,直接看学院君的译文吧,已经写得很详细了 传送门:http://laravelacademy.org/post/6191.html PS1: laravel的关联模型并不是遍历一次 ...

  10. docker学习-docker核心技术

    镜像:集装箱     ---build 仓库:超级码头  ----ship 容器:运行程序的地方    ----run docker运行一个程序的过程:去仓库把镜像拉到本地,然后用一条命令把镜像运行起 ...