一、什么是存储过程
先简单看几个简单的存储过程,熟悉一下存储过程的格式套路
create or replace procedure myDemo01
as
begin
dbms_output.put_line('我是菜鸟起飞');
end;
复制
create or replace procedure:关键字用来创建或覆盖一个原有的存储过程。
myDemo01:自定义的存储过程的名字。
as:关键字。
begin:关键字。
dbms_output.put_line('我是菜鸟起飞'):输出内容。
end:关键字。
第一个存储过程的调用(三种方式调用):
①声明declare关键字进行调用
declare
begin
myDemo01;
end;
复制
begin
myDemo01; --在此处也可使用myDemo01();完成存储过程的调用
end;
复制
call myDemo01();--call 存储过程名可完成调用,注意括号不能少
复制
2、第二个存储过程:变量声明,赋值
create or replace procedure myDemo02
as
name varchar(10);--声明变量,注意varchar需要指定长度
age int;
begin
name:='菜鸟起飞';--变量赋值
age:=18;
dbms_output.put_line('name='||name||', age='||age);--通过||符号达到连接字符串的功能
end;
复制
create or replace procedure myDemo03(name in varchar,age in int)
as
begin
dbms_output.put_line('name='||name||', age='||age);
end;
复制
begin
myDemo03('菜鸟起飞',18);
end;
复制
create or replace procedure myDemo04(name in varchar,age in int)
as
begin
dbms_output.put_line('name='||name||', age='||age);
end;
复制
declare
name varchar(10);
age int;
begin
name:='菜鸟起飞';
age:=18;
myDemo04(name=>name,age=>18);--此时不能myDemo04(name=>name,18),不能完成调用。
end;
复制
create or replace procedure myDemo05(name out varchar,age in int)
as
begin
dbms_output.put_line('age='||age);
select 'xiaoming' into name from dual;
end;
复制
declare
name varchar(10);
age int;
begin
myDemo05(name=>name,age=>10);
dbms_output.put_line('name='||name);
end;
复制
6、第六个存储过程:异常问题,执行结果见下图
create or replace procedure mydemo0006
as
age int;
begin
age:=10/0;
dbms_output.put_line(age);
exception when others then
dbms_output.put_line('error');
end;
复制
存储过程的调用:
begin
mydemo0006();
end;
复制
参考链接:https://www.cnblogs.com/dc-earl/articles/9260111.html
文章转载自软件实施干货分享,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1222次阅读
2025-03-13 11:40:53
Oracle RAC ASM 磁盘组满了,无法扩容怎么在线处理?
Lucifer三思而后行
739次阅读
2025-03-17 11:33:53
Oracle+Deepseek+Dify 实现数据库数据实时分析
bicewow
653次阅读
2025-03-06 09:41:49
【ORACLE】ORACLE19C在19.13版本前的一个严重BUG-24761824
DarkAthena
544次阅读
2025-03-04 14:33:31
Oracle避坑指南|同名表导出难题:如何精准排除指定用户下的表?
szrsu
503次阅读
2025-03-05 00:42:34
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
440次阅读
2025-03-13 14:38:19
Ogg23ai高手必看-MySQL Innodb Cluster跟oracle的亲密接触
曹海峰
437次阅读
2025-03-04 21:56:13
【ORACLE】char类型和sql优化器发生的“错误”反应
DarkAthena
399次阅读
2025-03-04 23:05:01
什么,oracle 主机用户被删了?原来是虚惊一场!
Lucifer三思而后行
394次阅读
2025-03-03 21:12:09
Oracle 如何修改 db_unique_name?强迫症福音!
Lucifer三思而后行
326次阅读
2025-03-12 21:27:56