问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

oracle 存储过程 begin end

发布网友 发布时间:2022-04-07 18:45

我来回答

3个回答

热心网友 时间:2022-04-07 20:15

Oracle存储过程基础知识
商业规则和业务逻辑可以通过程序存储在Oracle中,这个程序就是存储过程。
存储过程是SQL, PL/SQL, Java 语句的组合,它使你能将执行商业规则的代码从你的应用程序中移动到数据库。这样的结果就是,代码存储一次但是能够被多个程序使用。
要创建一个过程对象(proceral object),必须有 CREATE PROCEDURE 系统权限。如果这个过程对象需要被其他的用户schema 使用,那么你必须有 CREATE ANY PROCEDURE 权限。执行 procere 的时候,可能需要excute权限。或者EXCUTE ANY PROCEDURE 权限。如果单独赋予权限,如下例所示:
grant execute on MY_PROCEDURE to Jelly
调用一个存储过程的例子:
execute MY_PROCEDURE( 'ONE PARAMETER');
存储过程(PROCEDURE)和函数(FUNCTION)的区别。
function有返回值,并且可以直接在Query中引用function和或者使用function的返回值。
本质上没有区别,都是 PL/SQL 程序,都可以有返回值。最根本的区别是: 存储过程是命令, 而函数是表达式的一部分。比如:
select max(NAME) FROM
但是不能 exec max(NAME) 如果此时max是函数。
PACKAGE是function,procere,variables 和sql 语句的组合。package允许多个procere使用同一个变量和游标。

创建 procere的语法:

CREATE [ OR REPLACE ] PROCEDURE [ schema.]procere
[(argument [IN | OUT | IN OUT ] [NO COPY] datatype
[, argument [IN | OUT | IN OUT ] [NO COPY] datatype]...
)]
[ authid { current_user | definer }]
{ is | as } { pl/sql_subprogram_body |
language { java name 'String' | c [ name, name] library lib_name
}]
Sql 代码:
CREATE PROCEDURE sam.credit (acc_no IN NUMBER, amount IN NUMBER) AS
BEGIN
UPDATE accounts
SET balance = balance + amount
WHERE account_id = acc_no;
END;
可以使用 create or replace procere 语句, 这个语句的用处在于,你之前赋予的excute权限都将被保留。
IN, OUT, IN OUT用来修饰参数。
IN 表示这个变量必须被调用者赋值然后传入到PROCEDURE进行处理。
OUT 表示PRCEDURE 通过这个变量将值传回给调用者。
IN OUT 则是这两种的组合。
authid代表两种权限:
定义者权限(difiner right 默认),执行者权限(invoker right)。
定义者权限说明这个procere中涉及的表,视图等对象所需要的权限只要定义者拥有权限的话就可以访问。
执行者权限则需要调用这个 procere的用户拥有相关表和对象的权限。

Oracle存储过程的基本语法
1.基本结构
CREATE OR REPLACE PROCEDURE 存储过程名字
(
参数1 IN NUMBER,
参数2 IN NUMBER
) AS
变量1 INTEGER :=0;
变量2 DATE;
BEGIN
END 存储过程名字
2.SELECT INTO STATEMENT
将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条
记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)
例子:
BEGIN
SELECT col1,col2 into 变量1,变量2 FROM typestruct where xxx;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xxxx;
END;
...

3.IF 判断
IF V_TEST=1 THEN
BEGIN
do something
END;
END IF;
4.while 循环
WHILE V_TEST=1 LOOP
BEGIN
XXXX
END;
END LOOP;
5.变量赋值
V_TEST := 123;
6.用for in 使用cursor
...
IS
CURSOR cur IS SELECT * FROM xxx;
BEGIN
FOR cur_result in cur LOOP
BEGIN
V_SUM :=cur_result.列名1+cur_result.列名2
END;
END LOOP;
END;
7.带参数的cursor
CURSOR C_USER(C_ID NUMBER) IS SELECT NAME FROM USER WHERE TYPEID=C_ID;
OPEN C_USER(变量值);
LOOP
FETCH C_USER INTO V_NAME;
EXIT FETCH C_USER%NOTFOUND;
do something
END LOOP;
CLOSE C_USER;
8.用pl/sql developer debug
连接数据库后建立一个Test WINDOW
在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试

9.Pl/Sql中执行存储过程
在sql*plus中:
declare
--必要的变量声明,视你的过程而定
begin
execute yourprocure(parameter1,parameter2,...);
end
/
在SQL/PLUS中调用存储过程,显示结果:
SQL>set serveoutput on --打开输出
SQL>var info1 number; --输出1
SQL>var info2 number; --输出2
SQL>declare
var1 varchar2(20); --输入1
var2 varchar2(20); --输入2
var3 varchar2(20); --输入2
BEGIN
pro(var1,var2,var3,:info1,:info2);
END;
/
SQL>print info1;
SQL>print info2;
注:在EXECUTE IMMEDIATE STR语句是SQLPLUS中动态执行语句,它在执行中会自动提交,类似于DP中FORMS_DDL语句,在此语句中str是不能换行的,只能通过连接字符"||",或着在在换行时加上"-"连接字符。

热心网友 时间:2022-04-07 21:33

我理解就是用begin end界定一个代码块,跟C语言中的{}是同一个意思。
比如:
CREATE Procere()
as
begin
。。。
/*
if ()
begin
...
end
else
begin
...
end
*/
end
而这里省略号位置如果又出现了While循环或者IF ELSE判断,当然就又需要界定范围了,你不能在里面用{},只能嵌套begin end。
我怎么才看见这个贴呢。

热心网友 时间:2022-04-07 23:07

第一,beginend是存储过程执行块的首尾。
第二,没听说过嵌套。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
鸿蒙NEXT EROFS 文件系统有何大优势_鸿蒙 NEXT 中的EROFS文件系统优势介... Huawei EROFS 初探 [科普] 华为P30系列手机黑科技EROFS解密 Linux磁盘剩余空间查看方法 招行信用卡分期利息多少钱招行信用卡分期利息 公司哪些事情千万不要告诉同事? 爱奇艺怎么用小米账号登录 抖音上的音乐怎么设置手机铃声 c1转c2需要什么条件考完科二 徐州c1转c2可以吗 河南都有哪些旅游景点。具体门票是多少? 五月河南旅游有哪些景点是必去的 河南有什么旅游景区 王者荣耀孙尚香末日机甲宣传动画怎么打开 债券市场体现了流动性和收益性的统一 怎么理解 王者荣耀孙尚香新皮肤沉稳之力值得入手吗 孙尚 漯河十大著名旅游景点 漯河有什么著名景 我对债券市场的认识是一个盲区?和股票市场有相似性吗? 孙尚香的沉稳之力会优化吗 王者荣耀孙尚香新皮肤沉稳之力值得入手吗 我想找个心理医生问问 我是怎么回事 孙尚香新皮肤可以赠送给别人嘛 请结合我国目前债券市场,阐述你对国债概念的认识,并说明你对投资于债券市场的看法 中山市哪里有心理咨询服务? 《王者荣耀》孙尚香双生皮肤正式出炉,这有受到玩家的喜欢吗? 沈阳市哪有好的心理诊所或咨询中心?要亲身经历过的(不要复制) 王者荣耀孙尚香皮肤沉稳怎么领取 泉州河市有哪里好玩的地方 惠阳淡水有没有心理医生? 王者荣耀获得新皮肤怎么炫耀皮肤视频? 天涯明月刀怎么退出帮派 天涯明月刀怎么返回,但不退出游戏。 天涯明月刀怎么退出全屏模式 天涯明月刀万里杀怎么退出帮派 请问营运车辆转为非营运车辆的年限是多少年? 天涯明月刀里帮主怎么退出帮派? 天涯明月刀ol退出位面 天涯明月刀剧情可以跳过吗?怎么跳剧情 天涯明月刀点进帮帮精灵光标不见了,怎么退出 天涯明月刀怎样退出话本 天刀助手怎么退出群聊天室? 2016款卡罗拉双擎营转非,可以在泉州过户,能开几年 天涯明月刀进入游戏剧情怎么快进退出 天涯明月刀侠客岛别苑升级中能退出游戏吗 天涯明月刀投票活动怎么退出登录 天刀怎么退出家园位面啊?用家园界面按钮进去家园位面之后出不来了,只能卡图吗 失信被执行人可以转让股权吗 天涯明月刀怎么退出选盟会 天涯明月刀怎么强制退剧情副本 营转非的车能开几年。?