Procedural Language和SQL的结合体。通过增加变量、控制语句,使我们可以写些逻辑更加复杂的数据库操作

语句框架组成

declare – 可选
声明各种变量或游标的地方。
begin – 必要
开始执行语句。
--单行注释语句用两个连在一起的‘-’表示。
/*多行注释语句,
可以换行*/
exception – 可选
出错后的处理。
end; – 必要(请注意end后面的分号)
简单helloworld程序
 declare
v_temp number(6):=123; /* := 是一个赋值符号 */
begin
dbms_output.put_line('middle');
dbms_output.put_line(v_temp);
end;
注意

要想显示程序的东西需要设置环境

 set serveroutput off -->关闭输出(默认关闭)
set serveroutput on -->打开输出
基本数据类型
    • Number 数字型
    • Int 整数型
    • Pls_integer 整数型,产生溢出时出现错误
    • Binary_integer 整数型,表示带符号的整数
    • Char 定长字符型,最大255个字符
    • Varchar2 变长字符型,最大2000个字符
    • Long 变长字符型,最长2GB
    • Date 日期型
    • Boolean 布尔型(TRUE、FALSE、NULL三者取一)
    • %type 表示不需要知道具体的一个字段类型,与指定的字段类型一致即可。例如:v_empno emp.empno%type;
    • %rowtype 与表结构完全一致 %rowtype 举例:

 declare
v_tt emp%rowtype;
begin
select * into v_tt from emp where empno=7521;
dbms_output.put_line(v_tt.job);
dbms_output.put_line(v_tt.sal);
end; 输出:SALESMAN
1250

varray

定义语法

TYPE VARRAYNAMEIS VARRAY(SIZE) OF ELEMENTTYPE [NOT NULL];

    • 其中,varrayname是VARRAY数据类型的名称,size是正整数,表示可以容纳的成员的最大数量,每个成员的数据类型是elementtypeo默认时,成员可以取空值,否则需要使用NOT NULL加以限制。

    • 数组是具有相同数据类型的一组成员的集合。每个成员都有一个唯一的下标,它取决于成员在数组中的位置。在PL/SQL中,数组数据类型是VARRAY(variable array,即可变数组)。

 declare
type my_varray is varray(2) of varchar2(12) not null;
varray_my my_varray;
begin
varray_my:=my_varray('dsa','sdafds');
dbms_output.put_line(varray_my(1));
end;
    • 如果初始化数量大于设定的大小,会报下标超出限制异常

    • 如果初始化数量小于设定的大小,会按照初始化数量进行设定大小,访问不存在数据的下标(即使在设定范围内).也会报异常

 DECLARE
--定义一个最多保存5个VARCHAR(25)数据类型成员的VARRAY数据类型
TYPE reg_varray_type IS VARRAY(5) OF VARCHAR(25);
--声明一个该VARRAY数据类型的变量
v_reg_varray REG_VARRAY_TYPE;
BEGIN
--用构造函数语法赋予初值
v_reg_varray := reg_varray_type
('中国', '美国', '英国', '日本', '法国');
DBMS_OUTPUT.PUT_LINE('地区名称:'||v_reg_varray(1)||'、'
||v_reg_varray(2)||'、'
||v_reg_varray(3)||'、'
||v_reg_varray(4));
DBMS_OUTPUT.PUT_LINE('赋予初值NULL的第5个成员的值:'||v_reg_varray(5));
--用构造函数语法赋予初值后就可以这样对成员赋值
v_reg_varray(5) := '法国';
DBMS_OUTPUT.PUT_LINE('第5个成员的值:'||v_reg_varray(5));
END;

table

    • 定义记录表(或索引表)数据类型。它与记录类型相似,但它是对记录类型的扩展。它可以处理多行记录,类似于C语言中的二维数组,使得可以在PL/SQL中模仿数据库中的表。
定义记录表类型的语法如下:

TYPE TABLE NAME IS TABLE OF ELEMENT_TYPE [NOT NULL] INDEX BY [BINARYINTEGER|LSINTEGER|VARRAY2];

    • 关键字INDEX BY表示创建一个主键索引,以便引用记录表变量中的特定行。 BINARY_INTEGER的说明
    • 如语句:TYPE NUMBERS IS TABLE OF NUMBER INDEX BY BINARYINTEGER;其作用是,加”INDEX BYBINARYINTEGER ”后,NUMBERS类型的下标就是自增长,NUMBERS类型在插入元素时,不需要初始化,不需要每次EXTEND增加一个空间。
    • 而如果没有这句话“INDEXBY BINARY_INTEGER”,那就得要显示对初始化,且每插入一个元素到NUMBERS类型的TABLE中时,都需要先EXTEND。

 --table 不能像varray一样初始化数据,只能一个一个赋值
declare
type table_my is table of number not null index by binary_integer;-- by binary_integer表示创建一个主键索引,以便引用记录表变量中的特定行。
my_table table_my;
begin
my_table(1):=23;
my_table(2):=24;
my_table(3):=24;
dbms_output.put_line(my_table(1));
end; 结果: 23 ---table结合rowtype的使用
declare
type table_my is table of emp%rowtype index by binary_integer; my_table table_my;
begin
select * BULK COLLECT into my_table from emp ;
for i in my_table.first..my_table.last loop
dbms_output.put_line(my_table(i).empno||'=='||my_table(i).ename||'=='||my_table(i).job);
end loop;
end; 结果:1357==oracle==
7369==SMITH==CLERK
7499==ALLEN==SALESMAN
...
table常见方法

record

    • 定义记录数据类型。它类似于C语言中的结构数据类型(STRUCTURE),PL/SQL提供了将几个相关的、分离的、基本数据类型的变量组成一个整体的方法,即RECORD复合数据类型。在使用记录数据类型变量时,需要在声明部分先定义记录的组成、记录的变量,然后在执行部分引用该记录变量本身或其中的成员。
定义记录数据类型的语法如下:

TYPE RECORDNAME IS RECORD(
  V1 DATA
TYPE1 [NOT NULL][:=DEFAULTVALUE],
  V2 DATATYPE2 [NOT NULL][:=DEFAULTVALUE],
  VN DATA
TYPEN [NOT NULL][:=DEFAULT_VALUE]
);

 ---record实现多列多行查询
declare
type my_record is record(
v_empno emp.empno%type,
v_ename emp.ename%type,
v_job emp.job%type
);
type my_table is table of my_record index by binary_integer;
table_my my_table;
begin
select empno,ename,job BULK COLLECT into table_my from emp ;
for i in table_my.first..table_my.last loop
dbms_output.put_line(table_my(i).v_empno||'=='||table_my(i).v_ename||'=='||table_my(i).v_job);
end loop;
end;
结果同上一个table

boolean

    • 布尔值只有TRUE, FALSE及 NULL 三个值

单行取值select

语法格式

select 字段 into 变量 from 表 where 条件

    1. 将查询到得数据放入变量中
    2. 确保必须有唯一一个字段
    3. 不能存在多个值,也不能为空,否则报错
    4. 将查询到得数据放入变量中

异常处理,一级自定义异常

语法格式

EXCEPTION
  WHEN firstexception THEN code to handle first exception 
  WHEN second
exception THEN code to handle second exception
  WHEN OTHERS THEN code to handle others exception 
END;

    • 异常处理可以按任意次序排列,但 OTHERS 必须放在最后
常见异常

自定义异常:

 declare
v_exception exception;
v_sal emp.sal%type;
begin
select sal into v_sal from emp where empno=7521;
if v_sal>1000 then
raise v_exception;
else
dbms_output.put_line('还可以');
end if;
exception
when v_exception then
dbms_output.put_line('钱太少啦');
end; 结果:钱太少啦

自定义错误----------------

 declare
v_sal emp.sal%type;
begin
select sal into v_sal from emp where empno=7521;
if v_sal>1000 then
raise_application_error('-20000','工资太低啦');
else
dbms_output.put_line(v_sal);
end if; end;
结果:会弹出弹出框错误

PLSQL嵌套DML的 insert update delete

    1. 直接使用
    2. DML语句起作用或者回退的话,需要显式的调用commit或者rollback
    3. sql%rowcount属性来记录最后一条SQL语句影响了多少 条记录
insert
 declare
v_empno emp.empno%type:=&s_empno;
begin
insert into emp(empno,ename) values(v_empno,'张三');
if v_empno>4 then
rollback;
raise_application_error('-20000','不能这样插滴~~');
end if;
end;
结果弹出错误.
update和delete用法同上

execute immediate的用法

    • 拼接字符串:标准的sql语句
    • execute immediate +字符串
    • execute immediate +字符串 into 变量 using 参数

- execute immediate 执行ddl语句或dml语句或dcl语句 (标准的sql语句)

   ----1---
declare
v_sql varchar2(122):='insert into emp(empno,ename) values(:a,:b)';
begin
execute immediate v_sql using 111,'shfdk';
commit;
end; ----2-----
declare
v_sql varchar2(122) := 'select ename from emp where sal=:a';
v_name emp.ename%type;
begin
execute immediate v_sql
into v_name
using 800;
dbms_output.put_line(v_name);
end;

循环结构

when
 打印偶数
declare
v_num number(3, 0) := 0;
begin
loop
dbms_output.put_line(v_num);
v_num := v_num + 2;
exit when v_num = 100;
end loop;
end;
for循环
 打印乘法口诀表
begin
for i in 1..9 loop
for j in 1..i loop
dbms_output.put(j||'*'||i||'='||(i*j)||chr(9));
if i=j then dbms_output.new_line();
end if;
end loop;
end loop;
end;

PLSQL语法的更多相关文章

  1. PLSQL语法深入浅出

    一:PLSQL概览:PLSQL 是Oracle公司在SQL基础上进行扩展而成的一种过程语言.PLSQL提供了典型的高级语言特 性,包括封装,例外处理机制,信息隐藏,面向对象等:并把新的编程思想带到了数 ...

  2. pl/sql programming 02 创建并运行plsql代码

    /* * chap 02 * ------------------------------------------------- */ create or replace function wordc ...

  3. Oracle总结第三篇【PLSQL】

    PLSQL介绍 PLSQL是Oracle对SQL99的一种扩展,基本每一种数据库都会对SQL进行扩展,Oracle对SQL的扩展就叫做PLSQL- SQL99是什么 (1)是操作所有关系型数据库的规则 ...

  4. Oracle总结【PLSQL学习】

    PLSQL介绍 PLSQL是Oracle对SQL99的一种扩展,基本每一种数据库都会对SQL进行扩展,Oracle对SQL的扩展就叫做PLSQL... SQL99是什么 (1)是操作所有关系型数据库的 ...

  5. plsql常用方法-转

    在SQLPLUS下,实现中-英字符集转换alter session set nls_language='AMERICAN';alter session set nls_language='SIMPLI ...

  6. Oracle PLSQL数据导出csv的案例

    之前项目运维人员碰到一个问题,需要写一个存储过程,把数据导出为csv文件,查了一些资料,帮他写成了一个PLSQL,今天拿出来分享一下,不足之处,欢迎指教. 数据背景:  用到两张表,一张存放单位组织名 ...

  7. Oracle数据库——Scheduler Job

    日常的运维工作中,我们经常使用Linux Server的anacron服务来使得服务器执行一下计划之内的任务,可以按照特定的时间间隔,重复的执行相关的命令或者相关的脚本,来完成预期的目标,能够节省相关 ...

  8. 【Oracle经典】132个oracle热门精品资料——下载目录

    电子书为网友wglzaj精心整理,这批资料下载量好评率都非常高,广受oracle学习者欢迎.文档共整理了12个精品专题和120个热门资料的下载地址,推荐给大家希望大家喜欢. 目录0豆下载地址:http ...

  9. C# DataTable.Select() 筛选数据

    有时候我们需要对数据表进行筛选,微软为我们封装了一个公共方法, DataTable.Select(),其用法如下: Select() Select(string filterExpression) S ...

随机推荐

  1. 终端命令对字符串进行sha1、md5、base64、urlencode/urldecode

    sha1.md5.base64 mac $ echo -n foo|shasum 0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33 - $ 2c26b46b68ffc6 ...

  2. LINUX C的学习

    好吧看着LINUX那么多的命令好难受= =看到第三章有介绍C的编译的,先写下试试喽. 可以用gedit或者vim,老师虽然大肆吹捧vim的经典原谅用的真吉儿难受- -,一开始没安装vim用的gedit ...

  3. 实用工具类--第三方开源--Lazy

    下载地址 :https://github.com/ddwhan0123/Lazy 工具 描述 AnimationUtils 动画工具类 AppUtils APP相关信息工具类 AssetDatabas ...

  4. db2生成连续日期

    //生成时间段内连续日期 select * from ( select date('2008-01-01') + (row_NUMBER() over () -1) days AS datennn f ...

  5. 应该是实例化对象的没有对属性赋值时,自动赋值为null,但不是空指针对象引用

    此时会输出两个null. Users类的实例是myUsers,但是由于javabean的作用范围是page,所以前面页面传送的javabean的设置的属性全部不能接收到.所以对象myUsers属性为自 ...

  6. HDU - 1402 A * B Problem Plus (FFT实现高精度乘法)

    题意:计算A*B,A,B均为长度小于50000的整数. 这是FFT在大整数相乘中的一个应用,我本来想用NTT做的,但NTT由于取模很可能取炸,所以base必须设得很小,而且效率也比不上FFT. A和B ...

  7. UVA - 11212 Editing a Book (IDA*)

    给你一个长度为n(n<=9)的序列,每次可以将一段连续的子序列剪切到其他地方,问最少多少次操作能将序列变成升序. 本题最大的坑点在于让人很容易想到许多感觉挺正确但实际却不正确的策略来避开一些看似 ...

  8. CodeForces - 150C :Smart Cheater (线段树,求最大连续区间)

    I guess there's not much point in reminding you that Nvodsk winters aren't exactly hot. That increas ...

  9. Linux查找/扫描局域网打印机IP

    假设在 192.168.10.* 有一台网络打印机,但是我们不知道它的地址.一种笨方法就是在浏览器中依次输入 192.168.10.1 到 192.168.10.254,看是否出现管理页面. 另一种思 ...

  10. BZOJ3489:A simple rmq problem

    浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline ...