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. C++函数类型

    继续上一篇 #include <iostream> using namespace std; void swap1(int &v1, int &v2); typedef v ...

  2. PHP 正则表达式 及常用汇总

    Δ  定界符 Δ  字符域 Δ  修饰符 Δ  限定符 Δ  脱字符 Δ  通配符(正向预查,反向预查) Δ  反向引用 Δ  惰性匹配 Δ  注释 Δ  零字符宽     1.    平时做网站经常 ...

  3. bootstrap -- css -- 辅助类

    文本 文本颜色 如果文本是个链接,则鼠标移动到链接文本上的时候,文本会变暗 .text-muted:灰色 .text-primary:浅蓝色 .text-success:绿色 .text-info:深 ...

  4. erlang的简单模拟半包的产生

     gen_tcp:linsten()/2使用的是{packet,2/4/8},则gen_tcp模块在接受或者发送时自动除去包头或者自动加上包头. 本例中使用的是{packet,0}. -module( ...

  5. 基于swoole扩展实现真正的PHP数据库连接池

    转自:  http://rango.swoole.com/archives/265 PHP的数据库连接池一直以来都是一个难题,很多从PHP语言转向Java的项目,大多数原因都是因为Java有更好的连接 ...

  6. Unity 大版本更新之APK的下载与覆盖安装

    作为一个游戏开发者,更新这个技能是必不可少的!更新分为游戏内的更新,也就是所谓的资源热更包括AssetBundle更新和代码更新,代码其实也是所谓的二进制文件,在安卓上和普通资源文件毫无差异,然而在I ...

  7. Sass基础——Rem与Px的转换

    rem是CSS3中新增加的一个单位值,他和em单位一样,都是一个相对单位.不同的是em是相对于元素的父元素的font-size进行计算:rem是相对于根元素html的font-size进行计算.这样一 ...

  8. 数据库客户端快捷键(oracle+sybase)

    PL/SQL: 选中单行:鼠标三连击某行,那么这一行即被选中. 执行脚本:F8

  9. Redis(一)-- 基础

    一.Redis 简介 Redis 是完全开源免费的,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的持久化,可以将内 ...

  10. iOS 录音功能的实现

    这两天也调了一下ios的录音,原文链接:http://www.iphoneam.com/blog/index.php?title=using-the-iphone-to-record-audio-a- ...