Oracle11g R2学习系列 之九 PL/SQL语言
这是个重头戏,如果精通了PL/SQL,毫不夸张的说明精通了Oracle了。PL/SQL由以下三个部分组成(Definition,Manipulation,Control):
DDL:数据定义语言,Create,Alter,Drop等用于执行数据库的任务。
DML:数据操作语言,Select,Insert,Update,Delete等用于操纵数据库中各种对象、检索和修改数据。
DCL:数据控制语言,Grant,Remove等用于安全管理、确定哪些用户可以查看或修改数据库中数据。
PL/SQL的运算符有跟其他语言相似,也有数学运算符(+-*/等)和逻辑运算符(and,or,not),及其电他如赋值符:=,字符串分隔符' 及并置运算符||(这个要留意,ms sql中用的是+,C#及好多其它语言都是+).
变量:数据库与PL/SQL程序之间是通过变量进行数据传递的。基本格式
<变量名><数据类型>[(宽度):=<初始值>]; 例如,定义一个长度为10的变量count,其初始值为1,是varchar2类型。
count varchar2(10) := '';
关于数据类型,PL/SQL支持用户自定义类型。如自定义表类型,记录类型,输入下面的代码会输出abc字样出来。
set serveroutput on
declare
type t_xs is record
(
xh char(6),
xm char(8),
xb char(2),
zy char(12)
);
myxs t_xs;
begin
myxs.xh:='abc';
dbms_output.put_line(myxs.xh);
end;
为了美观和易于读写,以后关键字都大写好了。
如果要申明一个变量,其类型与表中的某列值相同,可以使用%Type属性,即语法是这样子的:
<变量名> 表名.列名%Type; 声明一个变量my_xh与表XSB中的XH列具有相同的数据类型,就可以这样子定义:
my_xh XSB.XH%TYPE;
而用于描述表的行数据的记录的时候,可以使用%RowType属性。一般用于游标,表示一行记录。如下所示利用游标查询出cjb中的所有cj值。记录一行数据的时候,用的就是%RowType属性。
Set ServerOutput On
Declare
Cursor cur
Is
Select xh,kch,cj From cjb;
cur_rec cur%RowType;
Begin
Open cur;
if cur%IsOpen then
loop
Fetch cur into cur_rec;
if cur%found then
Dbms_Output.put_line(cur_rec.cj);
else
exit;
end if;
end loop;
else
Dbms_Output.put_line('Cursoe is closed.');
end if;
Close cur;
End;
常量:程序运行过程中值不变的量。其语法格式:
<常量名>constant<数据类型>:=<值>;
PL/SQL块的基本结构如下所示:
[ DECLARE ] --声明部分 BEGIN --执行部分 [EXCEPTION] --异常处理部分 END
PL/SQL程序的结构跟其它语言大体相同,也有条件,循环,有case 语句,也有Goto语句。整个跟C#差不多,所以,不多列举,相信真要用的时候,自然而会条件反射出if...then...elseif...then...else,或者loop...exit...end loop等。我大概翻看了一下ppt教程,发现循环结构有以下4种:
1.LOOP-EXIT-END循环
语法格式:
LOOP
Run_expression /*执行循环体*/
IF Boolean_expression THEN /*测试Boolean_expression是否符合退出条件*/
EXIT; /*满足退出条件,退出循环*/
END IF;
END LOOP; 2.LOOP-EXIT-WHEN-END循环
除退出条件检测有所区别外,此结构与前一个循环结构类似。
语法格式:
LOOP
Run_expression /*执行循环体*/
EXIT WHEN Boolean_expression /*测试是否符合退出条件*/
END LOOP; 3.WHILE-LOOP-END循环
语法格式:
WHILE Boolean_expression /*测试Boolean_expression是否符合退出条件*/
LOOP
Run_expression /*执行循环体*/
END LOOP; 4.FOR-IN-LOOP-END循环
语法格式:
FOR count IN count_1..count_n /*定义跟踪循环的变量*/
LOOP
Run_expression /*执行循环体*/
END LOOP;
系统内置函数及自定义函数,内置属于API内容,是语言都会有。没什么稀奇,而且一般也差不多。自定义函数就是说使用如下的语法格式创建函数:
CREATE [OR REPLACE] FUNCTION function_name /*函数名称*/
(
parameter_name1, mode1 datatype1, /*参数定义部分*/
parameter_name2, mode2 datatype2,
parameter_name3, mode3 datatype3,
…
)
RETURN return_datatype /*定义返回值类型*/
{IS | AS}
[声明变量]
BEGIN
function_body; /*函数体部分*/
[RETURN scalar_expression;] /*返回语句*/
END [function_name];
包,在定义使用SELECT命令来查询数据库表数据时,一定要使用包头,否则无法实现存储过程的定义。Oracle提供了若干具有特殊功能的内置包。这些具有特殊功能的包如下。
(1)DBMS_ALERT包:用于数据库报警,允许会话间通信。
(2)DBMS_JOB包:用于任务调度服务。
(3)DBMS_LOB包:用于大型对象操作。
(4)DBMS_PIPE包:用于数据库管道,允许会话间通信。
(5)DBMS_SQL包:用于执行动态SQL。
(6)UTL_FILE包:用于文本文件的输入与输出
Oracle11g R2学习系列 之九 PL/SQL语言的更多相关文章
- Oracle11g R2学习系列 之二基本概念和环境介绍
昨天安装好了之后,发现用Chrome打开OEM发现是英文的,搞得我好奇怪:安装时明明自动显示的是中文的,为何会是英文的呢.后来想想会不会是Oracle用的是浏览器的语言呢,果断打开Chrome的设置, ...
- Oracle11g R2学习系列 之七安全性
其实,对于目前我使用的Oracle的水平来看,还达不到使用安全管理的高度,只是作为一个学习来看一下. 关于Oracle的安全管理,一般使用OEM来操作完成好了,入口是:OEM的“服务器”属性页中,选择 ...
- oracle 学习(五)pl/sql语言存储过程&包
首先搞清楚俩概念 存储过程(procedure)&程序包(package) 存储过程:数据库对象之一,可以理解为数据库的子程序,在客户端和服务器端可以直接调用它.触发器是与表直接关联的特殊存储 ...
- Oracle11g R2学习系列 之六数据库链接,快照及序列
Create public database link link_name Connect to user identified by password using 'DBName' 为'DBName ...
- Oracle11g R2学习系列 之五回闪
Oracle里面有一个回闪的操作,这个貌似sql server是没有的.要使用这个功能,需要用到两个时间内部函数 TIMESTAMP和TO_TIMESTAMP.其中,函数TO_TIMESTAMP的语法 ...
- Oracle11g R2学习系列 之一安装篇
前言 最近想去前同事推荐的一个Oracle相关的岗位竞争一下,由于之前没有使用Oracle的相关经验,所以决定学习一下,就算最终岗位应聘不成,至少也有了一些Oracle经验了,说不定哪天就用上了.再说 ...
- Oracle11g R2学习系列 之十 解决EM不能用
不知道是什么原因https://localhost:1158/em,今天突然就不能用了.做了好多搜索也没有解决.现象是在services.msc中,不能重启OracleDBConsole服务,提示: ...
- Oracle11g R2学习系列 之八高级数据类型
所谓的高级数据类型,就是大数据类型,即BCNB(助记词:BC牛逼)+XML数据类型. B:blob,用来存储可变长度的二进制数据. C:clob,主要用来存储可变长度的字符型数据,也就是其他数据库中提 ...
- Oracle11g R2学习系列 之四Maven+Struts+Spring实验
今天试一下Java调用Oracle来看一下.会不会也如昨天实验的一样坑呢?由于我对于Java也接触的不多,所以不打算直接使用该收提供的实验文档,而是自己利用Maven+Struts+Spring来自己 ...
随机推荐
- ajax初学
//参数说明url:请求文件地址//fnSucc:请求成功执行的函数,请求成功的条件为readyState状态码为4:且status状态码为200,status状态为浏览器请求返回的状态码//在fnS ...
- mysql数据修改-DEDE
update `dede_arctype` set `templist`='{style}/products.htm' where `templist`='{style}/Product.htm' d ...
- Flask学习记录之Flask-Admin
相信用过Django框架的都不会忘记它强大的Admin功能,Flask-admin是一款能够与Django Admin所媲美的扩展,能够快速创建Web管理界面,实现了用户.文件增删改查等常用功能:也可 ...
- Spring MVC URL传参
Spring MVC 学习 之 - URL参数传递 在学习 Spring Mvc 过程中,有必要来先了解几个关键参数: @Controller: 在类上注解,则此类将编程一个控制器,在项目启 ...
- mongoDB初探
最近在努力学习node方面的东西,看别人的资料里提到最多用到的数据库还是mongoDB,早打算下载下来试一下,由于电脑新配置,网络也由于住的地方现在上不了网暂时用的手机4G网络在凑合,这里面也踩到了不 ...
- 如何修改Qt标准对话框的文字(例如,英文改成中文)
此篇文章参考qtcn论坛整理而成,因为文字和图片是本人亲自组织,所以仍算原创. http://www.qtcn.org/bbs/read-htm-tid-30650.html http://blog. ...
- HP的笔记本经常蓝屏崩溃 -------athr.sys
因为windows 7才新装不久,没有时间下载配置什么符号表,直接临时下载了WinDbg分析下Dump文件, Probably caused by : athr.sys ( athr+428a5 ) ...
- socket使用TCP协议时,send、recv函数解析以及TCP连接关闭的问题
Tcp协议本身是可靠的,并不等于应用程序用tcp发送数据就一定是可靠的.不管是否阻塞,send发送的大小,并不代表对端recv到多少的数据. 在阻塞模式下, send函数的过程是将应用程序请求发送的数 ...
- bzoj3039 玉蟾宫
Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地.这片土地被分成N*M个格子,每个格子里写着'R'或者' ...
- win8开机密码忘了怎么办
原文地址:http://zhidao.baidu.com/question/582486883100064325.html windows8系统虽然让众用户用着不习惯,但是还是拥有大批追随者.今天,绿 ...