【SQL】Oracle的PL/SQL语法及其拓展数据类型总结
PL/SQL语法
PL/SQL程序由三部分组成,声明部分、执行部分、异常处理部分。
模板:
DECLARE
/*变量声明*/
BEGIN
/*程序主体*/
EXCEPTION
/*异常处理部分*/
END;
接收用户的输入信息
PL/SQL 块还可以接收用户的输入信息,例如:现在要求用户输入一个雇员编号,之后根据输入的内容进行查询,查询雇员的姓名。
用户的输入信息使用“&”完成。
范例:
DECLARE
t_eno NUMBER ;
t_ename VARCHAR2(30) ;
BEGIN
-- 输入的信息保存在 eno 里
t_eno := &no;
-- 之后根据 eno 的值,对数据库进行查询操作
SELECT ename INTO t_ename FROM emp WHERE empno=t_eno ;
DBMS_OUTPUT.put_line('编号为:'||t_eno||'雇员的姓名为:'||t_ename) ;
EXCEPTION
WHEN no_data_found THEN DBMS_OUTPUT.put_line('没有此雇员') ;
END ;
自定义数据类型之%type
定义一个变量,可以将其与表中某个列的数据类型一致。
如上例修改为以下也可运行。
DECLARE
t_eno emp.empno%type ;
t_ename emp.ename%type;
BEGIN
-- 输入的信息保存在 eno 里
t_eno := &no;
-- 之后根据 eno 的值,对数据库进行查询操作
SELECT ename INTO t_ename FROM emp WHERE empno=t_eno ;
DBMS_OUTPUT.put_line('编号为:'||t_eno||'雇员的姓名为:'||t_ename) ;
EXCEPTION
WHEN no_data_found THEN DBMS_OUTPUT.put_line('没有此雇员') ;
END ;
DECLARE
t_eno emp.empno%type ;
t_ename emp.ename%type;
BEGIN
-- 输入的信息保存在 eno 里
t_eno := &no;
-- 之后根据 eno 的值,对数据库进行查询操作
SELECT ename INTO t_ename FROM emp WHERE empno=t_eno ;
DBMS_OUTPUT.put_line('编号为:'||t_eno||'雇员的姓名为:'||t_ename) ;
EXCEPTION
WHEN no_data_found THEN DBMS_OUTPUT.put_line('没有此雇员') ;
END ;
复合数据类型之record
将一个或多个标量封装成一个对象,由单行多列的标量构成的复合结构,组成类似于一维数组。
如下例查询表中两列将其放入记录类型并输出显示。
DECLARE
type rec_test1 is record(
t_empno emp.empno%type,
t_ename emp.ename%type
); --定义一个record类型
rt rec_test1;--使用你刚才定义的record类型,定义了一个变量rt.
BEGIN
select empno,ename into rt.t_empno,rt.t_ename from emp where empno=1001;
dbms_output.put_line('empno:'||rt.t_empno);
END ;
DECLARE
type rec_test1 is record(
a1 number,
a2 varchar2(10)
);
rt1 rec_test1;
rt2 rec_test1;
BEGIN
rt1.a1:=1;
rt1.a2:='china';
rt2.a1:=2;
rt2.a2:='usa';
dbms_output.put_line('rt1.a2:'||rt1.a2);
dbms_output.put_line('rt2.a2:'||rt2.a2);
END ;
复合数据类型之%rowtype
%ROWTYPE可以说是record的升级简化版。
区别在与前者结构为表结构,后者为自定义结构。
二者在使用上没有很大区别。前者方便,后者灵活。
在实际中根据情况来具体决定使用。
使用记录更新数据,如果用记录(RECORD)更新数据,那么只能使用记录成员;如果用%ROWTYPE更新数据,可以直接使用%ROWTYPE 。如:
DECLARE
vEmp emp%RowType;
Begin
select * InTo vEmp from empa where empa.EMPNO = '7934';
update empa set ROW = vEmp where EMPNO ='1111';
commit;
End;
【注】在进行如上操作前,需要复制表emp到empa。
复制表的结构
CREATE TABLE empa as SELECT * FROM emp WHERE 1=2;
复制表的数据
INSERT INTO empa SELECT * FROM emp;
Oracle扩展数据类型小结
%type:可让变量的类型与指定表的某列保持一致;
t_empno 表名.列名%type;
%record:单行多列,类似于一位数组;
1.先创建类型 2.再创建该类型的变量
type XXX is record(
列1 数据类型(长度),列2 数据类型(长度)…
);
x XXX; --x是变量, XXX是它的类型
如何引用某列? x.列名 即可
%rowtype: 是%record的升级简化版,可让其与某张表的结构完全一致.
x 表名%rowtype; --x是变量名
【SQL】Oracle的PL/SQL语法及其拓展数据类型总结的更多相关文章
- Oracle中PL/SQL简介、基本语法以及数据类型
Oracle中PL/SQL简介.基本语法以及数据类型 一.PL/SQL简介. Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询和Oracle自身过程控 ...
- Oracle之PL/SQL学习笔记
自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家 ...
- Oracle中PL/SQL的执行部分和各种流程控制
Oracle中PL/SQL的执行部分和异常部分 一.PL/SQL的执行部分. 赋值语句. 赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值:另一种是通过SQL查询结果赋值. 用户赋值举例: ...
- sql plus 和 pl/sql无法连接远程oracle数据库
前言:安装完oracle客户端后,可能会出现sql plus 和 pl/sql无法连接远程oracle数据库的情况,可能是以下原因: 针对sql plus连接不上: 1 可能原因:之前安装过oracl ...
- Oracle SQL Developer,Oracle 开发工具之toad、SQL Developer、PL/SQL Developer等比较
参考: oracle 的几个开发工具比较 因Oracle几乎是中大型商业企业数据的首选,所以比较一下常用与Oracle的工具. Oracle SQL Developer 免费,一般开发使用足矣,常用. ...
- 使用oracle 的 PL/Sql 定时执行一个存储过程
CSDN日报20170322--<关于软件研发的一些体会总结> 同步博客至 CSDN ,让更多开发者看到你的文章 看微博技术大咖解析互联网应用架构实战 使用oracle 的 PL/Sql ...
- Oracle之PL/SQL Developer的下载与安装
PL/SQL是什么? PL/SQL Developer是一个集成开发环境(以下简称PL/SQL),专门开发面向Oracle数据库的应用.PL/SQL也是一种程序语言,叫做过程化SQL语言(Proced ...
- 在SQL中使用PL/SQL函数存在的问题
-----------------------------Cryking原创------------------------------ -----------------------转载请注明出处, ...
- Working with Numbers in PL/SQL(在PL/SQL中使用数字)
This article gives you all the information you need in order to begin working with numbers in your P ...
- SQL语句、PL/SQL块和SQL*Plus命令之间的区别
SQL语句.PL/SQL块和SQL*Plus命令之间的区别 原文链接:https://blog.csdn.net/liuzhushiqiang/article/details/12320941 在 ...
随机推荐
- (1)cocos2d-x-2.2.4搭建windows开发环境
Cocos2d-x-2.2.4搭建windows环境 软件需求 Windows系统(windows7或之后的系统): cocos2d-x-2.2.4压缩包. python安装包(推荐使用2.7.3版本 ...
- Hdu 4734 【数位DP】.cpp
题意: 我们定义十进制数x的权值为f(x) = a(n)*2^(n-1)+a(n-1)*2(n-2)+...a(2)*2+a(1)*1,a(i)表示十进制数x中第i位的数字. 题目给出a,b,求出0~ ...
- zabbix监控nginx连接状态(转)
zabbix监控nginx zabbix可以监控nginx的状态,关于一个服务的状态可以查看服务本身的状态(版本号.是否开启),还应该关注服务能力(例如以nginx的负载效果:连接数.请求数和句柄数) ...
- Java学习文件夹
每天进步一点点,先研究一门语言深入研究下去.
- 使用异步HTTP提升客户端性能(HttpAsyncClient)
使用异步HTTP提升客户端性能(HttpAsyncClient) 大家都知道,应用层的网络模型有同步.异步之分. 同步,意为着线程阻塞,只有等本次请求全部都完成了,才能进行下一次请求. 异步,好处是不 ...
- Hibernate常用Annotation标签说明
@ javax.persistence.Entity 实体类定义,该标签表示当前类是一个Hibernate的数据库实体,对应着数据库中的某个表 位置:用于类级别 参数:无 样例:@Entity 注意: ...
- poj 2992 Divisors 整数分解
设m=C(n,k)=n!/((n-k)!*k!) 问题:求m的因数的个数 将m分解质因数得到 p1有a1个 p2有a2个 .... 因为每一个质因数能够取0~ai个(所有取0就是1,所有取ai就是m) ...
- 百度mp3接口
歌曲ID 具体信息接口:http://tingapi.ting.baidu.com/v1/restserver/ting? from=android&version=2.4.0&met ...
- hdu4734(数位dp)
hdu4734 给定 a和b, 问区间[0,b]内有多少个数字的f(i) <=f(a) dp[i][s] 表示i位的数字的f<=s 所以比如如果第i+1位选择数字5之后, 那么只要剩下的i ...
- 无状态会话bean(3)---远程业务接口(没有排版)
迄今为止,我们仅仅讨论了使用一个本地业务接口的会话bean.在这样的情况下.本地意味着仅仅能由执行在同一个应用程序server实例的JavaEE组件声明会话bean的依赖性.比如.远程client不可 ...