PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块。每块由三个子部分组成:
1     声明
此部分开头使用关键字DECLARE。它是一个可选的部分,并限定在该程序中使用的所有变量,游标,子程序,和其他元素。
2     可执行命令
此部分是封闭关键字BEGIN和END,这是一个强制性的部分。它由程序的可执行文件的PL/SQL语句。它应具有至少一个可执行的代码行,这可能仅仅是一个空命令,以指示什么都不执行。
3     异常处理
此部分开头使用关键字EXCEPTION。此部分又是可选的,含有异常,在程序处理错误中。

这里是一个PL/SQL块的基本结构:
DECLARE
   <declarations section>
BEGIN
   <executable command(s)>
EXCEPTION
   <exception handling>
END;

一、声明
声明一个变量的语法是:
    [VARIABLE]    variable_name [CONSTANT] datatype [NOT NULL] [:= | DEFAULT initial_value]

变量声明
<变量名> 类型[:=初始值];

常量声明
<变量名> CONSTANT 类型:=初始值;        --示例: pi CONSTANT number(5,3):=3.14;

全局变量声明
VARIABLE <变量名> 类型;                        --示例: VARIABLE num number;

初始化变量
counter binary_integer := 0;
greetings varchar2(20) DEFAULT 'Have a Good Day';

变量的作用域
有两种类型的变量范围:
    局部变量 - 在[内部块中]声明,并不能访问外块中的变量。
    全局变量 - 在[最外层块]或包中声明的变量。

二、数据类型
基本数据类型和特殊数据类型
基本数据类型:number(p,s);varchar2(size);char(size);long;nvarchar2(size);nchar(size);date;boolean;real(与number等价);rowid(存放数据库的行号);
特殊数据类型:%type类型(单个字段);record类型(多个字段);%rowtype类型(一条记录)。

1、%type类型:声明一个与指定列相同的数据类型。
如:var_ename emp.ename%type;
声明的var_ename的数据类型与emp表中的ename列数据类型相同。

set serveroutput on                --设置系统输出的状态.
declare var_firstname EMPLOYEES.first_name%type;
var_job       EMPLOYEES.job_id%type;
begin
  ;
  SYS.dbms_output.put_line(var_firstname||'的工作是'||var_job);
end; 

2、record类型:也成为‘记录类型’,要先定义一个记录类型,再使用记录类型声明一个记录类型的变量。 如:

set serveroutput on
declare
type emp_type is record          /*先定义一个记录类型,emp_record为定义的记录类型名*/
(
var_a1 EMPLOYEES.first_name%type,
var_a2 EMPLOYEES.job_id%type,
var_a3 EMPLOYEES.salary%type
);
empinfo emp_type;              /*再声明一个记录类型的变量*/
begin
  ;
  dbms_output.put_line(empinfo.var_a1||'的工作是'||empinfo.var_a2||',并且工资是'||empinfo.var_a3);
end;

3、%rowtype类型:用来存储数据表中检索到的一行数据。

set serveroutput on
declare
var_row EMPLOYEES%rowtype;    /*emp_row表示变量名;emp为指定的表名,表示用来存储哪个表中的一行数据*/
begin
  ;
  dbms_output.put_line(var_row.first_name||'的工作是'||var_row.job_id||',并且工资是'||var_row.salary);
end;

三、语句语法

1、条件控制语句
IF <条件1> THEN
    语句
[ELSIF <条件2> THEN
   语句
     ....
ELSIF <条件n> THEN
   语句]
[ELSE
    语句]
END IF;

2、循环控制语句
1.LOOP
LOOP
   语句;
   EXIT WHEN <条件>
END LOOP;

2.WHILE LOOP
WHILE <条件>
LOOP
   语句;
END LOOP;

3.FOR
FOR <循环变量> IN 下限..上限
LOOP
   语句;
END LOOP;

三、NULL 语句
null;
表示没有操作;

四、
异常处理
EXCEPTION
   WHEN <异常类型> THEN
            语句;
   WHEN OTHERS THEN
            语句;
END;

Oracle pl/sql 基础入门语法的更多相关文章

  1. Oracle+PL+SQL从入门到精通.丁士锋.清华大学出版社.2012

    \t第1篇 pl/sql开发入门第1章 oracle 11g数据库系统1.1 关系型数据库系统介绍1.1.1 什么是关系型数据模型1.1.2 数据库系统范式1.1.3 关系型数据库管理系统1.1.4 ...

  2. 二十、oracle pl/sql基础

    一.pl/sql developer开发工具pl/sql developer是用于开发pl/sql块的集成开发环境(ide),它是一个独立的产品,而不是oracle的一个附带品. 二.pl/sql介绍 ...

  3. oracle pl/sql 基础

    一.pl/sql developer开发工具pl/sql developer是用于开发pl/sql块的集成开发环境(ide),它是一个独立的产品,而不是oracle的一个附带品. 二.pl/sql介绍 ...

  4. oracle PL/SQL基础编程

    PL/SQL(Procedural Language/SQL)是oracle中引入的一种过程化编程语言 PLS-00103:出现符号"declare"在需要下列之一时 符号&quo ...

  5. Oracle PL/SQL基础

    1.下载sql developer数据库连接可视化工具 连接地址:点我下载 下载完成,安装有Java环境,解压即可运行,也可以在linux系统中运行.

  6. Oracle PL/SQL入门之慨述

    Oracle PL/SQL入门之慨述 一.PL/SQL出现的目的 结构化查询语言(Structured Query Language,简称SQL)是用来访问关系型数据库一种通用语言,它属于第四代语言( ...

  7. Oracle PL/SQL语句基础学习笔记(上)

    PL/SQL是ORACLE对标准数据库语言的扩展,ORACLE公司已经将PL/SQL整合到ORACLE server和其它工具中了,近几年中很多其它的开发者和DBA開始使用PL/SQL,本文将讲述PL ...

  8. oracle PL/SQL编程基础知识

    在oracle中使用pl/sql来扩展SQL的功能,使得SQL能够更加的灵活,功能更加强大,效率更高.pl/sql让sql也能执行判断,循环等操作.主要记录一下pl/sql的基本语法和基本条件判断语句 ...

  9. ORACLE PL/SQL编程详解

    ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...

随机推荐

  1. [非原创] 常用加密算法整理 AES/SSL(一)

    前言: 在伟大的计算机科学家研究下,发明了许多的加密算法,以下做个简答的描述: 一.分类 加密算法分为两种:单向加密.双向加密. 单向加密,不可逆的加密算法,只能加密不能解密: 双向加密,由对称性加密 ...

  2. 怎么样修改win7下的host文件

    由于在访问tensorflow官网时访问不了,需要修改hosts文件,然而win7下因为权限问题导致不能修改hosts文件,解决方法如下: 1.先复制hosts文件到别的地方,修改完后再覆盖回来.中间 ...

  3. 唯一id UUID

    public static String getUUID() { String s = UUID.randomUUID().toString(); return s.substring(0, 8) + ...

  4. 利用Fiddler或Charles进行mock数据创造测试环境

    使用场景:服务器数据不符合测试条件时,我们可以通过在本地创建虚拟数据来打到测试用例所描述的条件. fiddler使用方法 1.首先在本地创建txt数据:将抓到的response中的json数据拷贝到记 ...

  5. grep搜索子目录中包含某字符串的特定文件

    grep -n "str" -r ./ 这是查找当前目录下以及下辖子目录下所有包含str字符串的文件,会列出文件名.以及该行的内容.以及行号 比如,我想搜源码目录src下,包含“n ...

  6. 2016 ACM-ICPC EC-Final题解

    题目链接 A. Number Theory Problem 题意:给你一个数N,求形如2k-1且小于2N的数中有多少能被7整除. 解法:观察二进制位找规律,答案是N/3. #include<bi ...

  7. java 实现树形结构

    package tree; import java.awt.BorderLayout; import java.awt.Color; import java.awt.Font; import java ...

  8. Nginx配置负载均衡服务器

    最近想买一台二手电脑当Linux服务器,一直没有买,暂时用windows来搞. Nginx下载地址:http://nginx.org/download/nginx-1.2.6.zip Tomcat下载 ...

  9. LoadRunner常见错误代码解决方案

    一.LoadRunner26377错误 通常不是长度的问题,如果长度有问题就都出错了.应该是服务器返回的数据问题,导致没有找到这个参数. 26377错误的成因很多,总结最直接的结果就是No match ...

  10. Qt中int转换成QString

    (1) QString QString::number ( long n, int base = 10 ) [static] examle: long a = 48; QString s = QStr ...