oracle数据库存储过程

一,基本语法
数据类型:
**(一)字符类型:**字符串数据类型还可以依据存储空间分为固定长度类型(CHAR)和可变长度类型(varchar2/nvarchar2)两种
1,char类型:定长字符串,会用空格填充来达到器最大长度,非null的char(12)总是包含12字节信息。char字段最多可以存储2000字节的信息。如果创建表时,不指定char长度,则默认为1。
2,varchar2类型:变长字符串,与char类型不同,它不会使用空格填充至最大长度。varchar2最多可以存储4000字节信息。
3,nvarchar2类型:这是一个包含unicode格式数据的变长字符串。nvarchar2最多可以存储4000字节的信息,长度并不是字节表示了,而是字符数量。比如nuarchar2(10)表示可以存储10个字符。
(二)数字类型
1,number类型:number(p,s)是常见的数据类型
p是precison的英文缩写,即精确缩写,表示有效数字的位数,最多不能超过38个有效数字;
s是scale的英文缩写,表示小数点数字的位数。
2,integer类型:integer是number的子类型,它等同于number(38,0),用来存储整数。若插入,更新的数值有小数,则会被四舍五入。
(三)浮点数
1,binary_float类型: binary_float是32位,单精度浮点数字数据类型。可以支持至少6位精度,每个binary_float的值需要5个字节,包括长度字节。
2,binary_double类型:binary_double是为64位,双精度浮点数字数据类型。每个binary_double的值需要9个字节,包括长度字节。
(四)日期类型
1,date类型:date是最常见的数据类型,日期数据类型存储日期和时间信息。虽然可以用字符或数字类型表示日期和时间信息,但是日期数据类型具有关联的属性。为每个日期值,Oracle存储如下信息:世纪,年,月,日,小时,分钟和秒,一般占用7个字节存储空间。
2,timestamp类型:这是一个7个字节或12字节的定宽日期时间数据类型。它与date数据类型不同,因为timestamp可以包含小数秒,带小数秒的timestamp在小数点右边最多可以保留9位数。
3,timestamp with time zone类型:这是timestamp类型的变种,它包含了时区的偏移量的值。
4,timestamp withlocal time zone类型:将时间一数据类库时区进行规范化后进行存储。
(五)lob类型
1,clob类型(Character Large Object):二进制数据,存储单字节和多字节字符数据。最大长度4G。
2,blob类型(Binary Large Object):它存储非结构化的二进制数据大对象,它可以被认为是没有字符集义的比特流,一般图像;声音;视频等文件,最大4G。
3,nclob数据类型:存储Unicode类型的数据,最大长度4G。
(六)long&raw&long raw类型
1,long类型:它存储变长字符串(超长字符串),最多达2G的字符数据(2GB是指两千兆字节,而不是两千兆字符)。
2,raw类型:用于存储二进制或字符类型数据,必须指定长度。这种数据类型的数据不会发生字符集转换。可存放多媒体图像声音等。
3,long raw类型:能存储2GB的原始二进制数据,可存放媒体图像声音等。
二,数据库存储过程语法
一)oracle数据路存储过程的创建(基本结构)
1,带参数的存储过程创建
CREATE OR REPLACE PROCEDURE 存储过程名字 (
–输入参数 IN NUMBER,
–输出参数 OUT NUMBER --可以有多个输入参数和输出参数
) IS
–这个区间可以用来定义变量和创建游标
BEGIN
–执行游标或者执行语句
commit; --对上面的内容进行提交
exception//存储过程异常
when others then
–异常处理方法,可以是打印错误,然后进行回滚等操作,下面操作一样,看自己情况决定
rollback;
dbms_output.put_line(sqlcode);
dbms_output.put_line(substr(sqlerrm, 1, 512));
END 存储过程名字;
注意:其中参数IN表示输入参数,是参数的默认模式。
OUT表示返回值参数,类型可以使用任意Oracle中的合法类型。
OUT模式定义的参数只能在过程体内部赋值,表示该参数可以将某个值传递回调用他的过程
IN OUT表示该参数可以向该过程中传递值,也可以将某个值传出去。
2,无参存储过程的创建
CREATE OR REPLACE PROCEDURE 存储过程名字
IS
–这个区间可以用来定义变量和创建游标
BEGIN
–执行游标或者执行语句
commit; --对上面的内容进行提交
exception//存储过程异常
when others then
–异常处理方法,可以是打印错误,然后进行回滚等操作,下面操作一样,看自己情况决定
rollback;
dbms_output.put_line(sqlcode);
dbms_output.put_line(substr(sqlerrm, 1, 512));
END 存储过程名字;
(二)变量的声明和赋值
1,变量的声明
a、按照数据类型进行声明
格式:变量名 变量的数据类型;
样例:v_name varchar2(500);
b、根据表字段进行声明
格式:变量名 表名.字段名%TYPE
样例:v_name userinfo.name%TYPE;
注意:变量的数据类型和表名的字段数据类型一致
c、根据表的行记录进行声明
格式:变量名 表名/游标名%ROWTYPE
样例:v_user_row userinfo%ROWTYPE;
注意:变量的数据类型和表的行数据类型一致
2,变量的赋值
a、直接赋值,需要使用:=进行赋值
使用的条件:只能在变量的声明a和b才能使用直接赋值
先声明在赋值(声明在上面a和b)
样例:v_name:= ‘小花’;
声明和赋值同时进行
v_name varchar(500) := ‘小花’
b、select 字段 into 变量 from 表名 进行赋值
单个字段复制:
select name into v_name from userinfo;
使用条件:也是只限于a和b使用
行记录复制:
select * into v_user_row from userinfo;
使用条件:也是只限于c使用
c、execute immediate sql语句 into 变量 进行赋值
v_name varchar2(500);
v_name_sql varchar2(500) :=‘select name from userinfo where id=1’;
execute immediate v_name_sql into v_name ;
语句含义是like执行v_name_sql 语句并将结果赋值给v_name。
(三)流程控制语句
1,条件控制语句 IF … THEN … END 或者 IF … ELSIF… THEN …END
基本语法:
IF 条件表达式1 THEN
语句段1
ELSIF 条件表达式2 THEN
语句段2

ELSIF 条件表达式n THEN
语句段n
END IF;
样例:如果flag_num=0则输出’早上好’,如果flag_num=1 则输出 ‘中午好’,否则输出’晚上好’,
declare
flag_num int:= 0;
begin
if flag_num=0 then
dbms_output.put_line(‘早上好’);
elsif flag_num=1 then
dbms_output.put_line(‘中午好’);
else
dbms_output.put_line(‘晚上好’);
end if;
end;
2,条件控制语句case
基本语法:
CASE
WHEN 条件表达式1 THEN
语句段1;
WHEN 条件表达式2 THEN
语句段2;

ELSE
语句段n;
END CASE;
样例:如果flag_num=0则输出’早上好’,如果flag_num=1 则输出 ‘中午好’,否则输出’晚上好’
declare
flag_num int:= 0;
begin
case
when flag_num=0 then dbms_output.put_line(‘早上好’);
when flag_num=1 then dbms_output.put_line(‘中午好’);
else dbms_output.put_line(‘晚上好’);
end case;
end;
3,循环控制语句
a,loop循环
基本语法:
LOOP
EXIT [WHEN 条件表达式] --循环终止条件,为ture时,退出循环,否则再次执行循环体
语句段;
END LOOP;
样例:
declare
i int:= 0;
begin
loop
EXIT WHEN i > 3;
i:=i+1;
dbms_output.put_line(i);
end loop;
end;
语句解释:初始变量i为0,当i进入loop循环时,i>3则退出循环,i等于i+1,进行打印,然后依次循环,直至i>3时退出循环。
b,while循环
基本语法:
WHILE 条件表达式 LOOP
语句段;
END LOOP;
样例:
declare
i int := 0;
begin
while i < 3 loop
i := i + 1;
dbms_output.put_line(i);
end loop;
end;
语句解释:初始变量i为0,当i进入loop循环时,i<3进入循环,i等于i+1,进行打印,然后依次循环,直至i不小于3时退出循环。
3,for循环
基本语法:(注意:如加上reverse表示倒叙循环执行语句)
FOR 循环变量 in [REVERSE] 初值表达式…终值表达式 LOOP
语句段;
END LOOP;
样例:
declare
i int := 0;
begin
for i IN reverse 1…5 loop
dbms_output.put_line(i);
end loop;
end;
语句解释:初始变量i为0,循环遍历1…5,for循环默认是递增,但是加上reverse 会变成递减,将5赋给i,打印i,直至将1…5全部循环遍历,结束循环,for循环只适用于已知循环次数的遍历。
(四)游标
1,游标的定义:
游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。游标存在隐式游标和显式游标。
2,隐式游标
DML操作和单行SELECT语句会使用隐式游标,它们分别是:
* 插入操作:INSERT。
* 更新操作:UPDATE。
* 删除操作:DELETE。
* 单行查询操作:SELECT … INTO …。
隐式游标使用样例:
a,创建一个包含name,age,addr三个字段的表
create table userinfo(
name varchar2(500);
age number(20);
addr varchar2(500);
)
b,编写插入的代码并用上面的游标属性进行监控
declare
begin
insert into userinfo (name,age,addr) values(‘zs’,18,‘sc’);
dbms_output.put_line(‘游标所影响的行数:’||SQL%rowcount);
if SQL%NotFound then --没有找到上面执行的sql
dbms_output.put_line(‘SQL%NotFound:true’);
else
dbms_output.put_line(‘SQL%NotFound:false’);
end if;
if SQL%Found then --找到上面执行的sql
dbms_output.put_line(‘SQL%Found:true’);
else
dbms_output.put_line(‘SQL%Found:false’);
end if;
if SQL%isopen then --游标是否打开
dbms_output.put_line(‘SQL%isopen:true’);
else
dbms_output.put_line(‘SQL%isopen:false’);
end if;
end;
c,执行的结果:
游标所影响的行数:1
SQL%NotFound:false
SQL%Found:true
SQL%isopen:false
d,编写一个查询的代码对游标属性进行监控
declare
v_info userinfo %ROWTYPE;
begin
select * into v_info from TEST_TABLE where name =‘zs’;
dbms_output.put_line(‘name:’||v_info.name);
dbms_output.put_line(‘age:’||v_info.age);
dbms_output.put_line(‘addr:’||v_info.addr);
dbms_output.put_line(‘游标所影响的行数:’||SQL%rowcount);
if SQL%NotFound then
dbms_output.put_line(‘SQL%NotFound:true’);
else
dbms_output.put_line(‘SQL%NotFound:false’);
end if;
if SQL%Found then
dbms_output.put_line(‘SQL%Found:true’);
else
dbms_output.put_line(‘SQL%Found:false’);
end if;
if SQL%isopen then
dbms_output.put_line(‘SQL%isopen:true’);
else
dbms_output.put_line(‘SQL%isopen:false’);
end if;
end;
e,查询的结果为:
name:zs
age:18
addr:sc
游标所影响的行数:1
SQL%NotFound:false
SQL%Found:true
SQL%isopen:false
3,显示游标
a,游标的声明
(1) 带参数的游标:
CURSOR 游标名 (参数1 数据类型,…)
IS
SELECT语句;
(2) 无参的游标:
CURSOR 游标名
IS
SELECT语句;
注意:SELECT语句是对表或视图的查询语句,甚至也可以是联合查询。可以带WHERE条件、ORDER BY或GROUP BY等子句,但不能使用INTO子句。
b,打开游标
在可执行部分,按以下格式打开游标:
OPEN 游标名(参数1,…) --存在参数
或者
OPEN 游标名 --不存在参数
打开游标时,SELECT语句的查询结果就被传送到了游标工作区。
c,提取数据
FETCH 游标名 INTO 变量;
游标打开后有一个指针指向数据区,FETCH语句一次返回指针所指的一行数据,要返回多行需重复执行,可以使用 循环语句来实现。控制循环可以通过判断游标的属性来进行。
d,关闭游标
CLOSE 游标名;
显式游标打开后,必须显式地关闭。游标一旦关闭,游标占用的资源就被释放,游标变成无效,必须重新打开才能使用。
4,游标的属性
通过游标的属性,来了解游标的执行状态和结果,进而控制游标的执行操作。隐式游标可以使用名字SQL来访问,但要注意,通过SQL游标名总是只能访问前一个DML操作或单行SELECT操作的游标属性。通常在刚刚执行完操作之后,立即使用SQL游标名来访问属性。
游标的属性有四种:
sql%found (布尔类型, 默认值为null)
sql%notfound(布尔类型, 默认值为null)
sql%rowcount(数值类型, 默认值为0)
sql%isopen(布尔类型)
a, SQL%FOUND和SQL%NOTFOUND
在执行任何DML语句前SQL%FOUND和SQL%NOTFOUND的值都是NULL,在执行DML语句后,
SQL%FOUND的属性值将是:
.TRUE :INSERT --判断是否插入成功
.TRUE :DELETE和UPDATE,至少有一行被DELETE或UPDATE.–判断修改和删除成功
.TRUE :SELECT INTO至少返回一行 --判断查询成功
当SQL%FOUND为TRUE时,SQL%NOTFOUND为FALSE。
b, SQL%ROWCOUNT
在执行任何DML语句之前,SQL%ROWCOUNT的值都是NULL, 对于SELECT INTO语句,如果执行成功,SQL%ROWCOUNT的值为1,如果没有成功或者没有操作(如update、insert、delete为0条),SQL%ROWCOUNT的值为0, 而对于update和delete来说表示游标所检索数据库行的个数即更新或者删除的行数。
c,SQL%ISOPEN
SQL%ISOPEN是一个布尔值,如果游标打开,则为TRUE, 如果游标关闭,则为FALSE.对于隐式游标而言SQL%ISOPEN总是FALSE,这是因为隐式游标在DML语句执行时打开,结束时就立即关闭。

oracle数据库存储过程基本语法相关推荐

  1. oracle数据库存储过程中NO_DATA_FOUND不起作用解决

    oracle数据库存储过程中NO_DATA_FOUND不起作用 1.首先创建一个表lengzijiantest,表中只有一个字段f_id ? 1 2 3 4 5 [cpp] CREATE TABLE ...

  2. oracle 数据库 触发器 trigger 语法

    http://shixm.iteye.com/blog/401564 关键字: oracle 数据库 触发器 trigger 语法 语法规则: Create [or replace] trigger ...

  3. Mysql数据库存储过程基本语法讲解

    Mysql数据库存储过程基本语法讲解 一般情况下MYSQL以:结尾表示确认输入并执行语句,但在存储过程中:不是表示结束,因此可以用该命令将:号改为//表示确认输入并执行.存储过程如同一门程序设计语言, ...

  4. 【AIO】使用ORACLE数据库存储过程发送企业微信群机器人消息

    前言 为了对标阿里系的钉钉,腾讯于2016年4月18日推出了企业微信 专注企业内部通讯(目前已加入客户管理及客户通讯功能),替代原有的RTX腾讯通 企业微信由于微信的生态及其易用性,已被很多企业使用, ...

  5. oracle数据库存储函数,Oracle数据库存储过程

    一.定义 所谓存储过程,就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过编译后存储在数据库系统中.使用的时候,用户通过指定已经定义的存储过程名字并给相应的存储过程参数来调用并执行它,从 ...

  6. Oracle数据库的基本语法

    注意:Oracle数据库中的字段值严格区分大小写. 1.         建立表 表约束的创建: 2.         使用数学符号:当我们的表中列包含数字列时,我们可以用相应的表达式对其进行查询,其 ...

  7. 编程开发之--Oracle数据库--存储过程在out参数中使用光标(3)

    在本系列学习随笔中的第2节我们留下了2个问题,我们现在讨论在out参数中使用光标. 1.要在out参数中使用光标,我们需要申明一个包的结构,包的结构分为包头和包体,包头只负责申明,包体只负责实现.包头 ...

  8. Oracle数据库查询数据语法

    查询数据 本节将学习如何从Oracle数据库中查询数据.我们将从一个简单的查询开始,从单个表中检索数据. Select语句 - 演示如何查询单个表中的数据. --查询语句: select 数据 fro ...

  9. oracle 数据库存储过程编译报错PLS-00103出现符号 end-of-file在需要下列之一时

    在oracle数据库创建可自动执行的存储过程中,编译时,出现如下错误: PLS-00103: 出现符号 "end-of-file"在需要下列之一时: ( begin case de ...

  10. oracle declare语法_基于oracle数据库存储过程的创建及调用

    教学大纲: PLSQL编程:Hello World.程序结构.变量.流程控制.游标. 存储过程:概念.无参存储.有参存储(输入.输出). JAVA调用存储存储过程. 1. PLSQL编程 1.1. 概 ...

最新文章

  1. Deepin ROMS 安装详细流程
  2. AI开发者们,2017年你们过得好吗?
  3. 产品经理10大基础技能(5):读透神经网络和机器学习
  4. .NET程序员的C\C++情结(3)
  5. leetcode917
  6. c socket双向通信 qq linux,请问如何实现像QQ那样2个内网用户的点到点SOCKET通信?...
  7. C# datetime 格式化
  8. Unit Testing with JUnit - Tutorial
  9. java texttospeech_TextToSpeech 文本自动朗读
  10. html播放m3u8格式转换,m3u8格式如何播放
  11. 六款很6的电脑驱动管理器:驱动升级用什么软件好 | 国外最好的电脑驱动管理软件推荐
  12. python开发erp系统odoo_odooERP系统(框架)总结
  13. 在服务器上搭建Cadence16.6 CIS共享库
  14. 王小九用计算机弹桥边姑娘,抖音最火歌曲是哪首?QQ音乐开放平台《桥边姑娘》让“野狼”靠边站...
  15. VSCode python extension loading 终极解决方案
  16. NSGA-II算法阅读笔记
  17. 美杜莎扫描器使用教程
  18. iOS学习笔记75-NSURLSession使用实战教程
  19. Win2000 蓝屏画面错误代码说明
  20. How to Install JAVA 8 (JDK 8u91) on Ubuntu LinuxMint via PPA

热门文章

  1. python删除列表第一个,在Python中删除列表的第一个元素
  2. 31、【栈和队列】判断链表是否为中心对称(C++版)
  3. 研发面试问题回答技巧
  4. 带手机版TOOL在线网页工具箱/站长工具源码/在线加密解密网站源码162个工具
  5. 项目上线质量如何评估
  6. iOS appIcon生成和设置
  7. 2020 微信头像圣诞帽来啦,快给 TA 戴帽子吧~
  8. 公众号网页授权php,微信公众号里的PHP网站进行网页授权
  9. 如何避免字节流读取文本乱码
  10. python-opencv尺寸测量