问答文章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是存储过程执行块的首尾。
第二,没听说过嵌套。
oracle存储过程用什么替代分号

用斜杠等。1、用斜杠代替分号,在存储过程的最后一条语句后面使用斜杠作为结束标志。2、使用BEGIN和END块,可以将存储过程的所有语句包裹在BEGIN和END块中,而不需要分号来分隔每个语句。

oracle 存储过程 begin end

存储过程是SQL, PL/SQL, Java 语句的组合,它使你能将执行商业规则的代码从你的应用程序中移动到数据库。这样的结果就是,代码存储一次但是能够被多个程序使用。要创建一个过程对象(procedural object),必须有 CREATE PROCEDURE 系统权限。如果这个过程对象需要被其他的用户schema 使用,那么你必须有 CRE...

oracle带参(传入,传出)的存储过程怎么执行

1、新建存储过程,Create or Replace Procedure CHK_SYS_EMP 检查系统工号。2、定义参数及变量:(TREV IN VARCHAR2,TRES OUT VARCHAR2) IS C_EMP VARCHAR2(25)。3、存储过程框架用Begin开始,End结束。4、查看需要调用表的结构以及相关字段。会用到表中的 EMP_NO ENABLED。5、存储过程按需添加SQL...

Oracle 存储过程怎么执行

DECLARE v_value VARCHAR2(100); --声明一个变量,用来存放返回的值BEGINP_MES_SB_JBEffectCheck('2010-01','2010-10',v_value); --执行存储过程P_MES_SB_JBEffectCheck,该存储过程接收2个时间值的参数,返回一个varchar类型的值END;注:Oracle存储过程不能返回一张表结构,所以在存储过程里执...

一个简单的oracle存储过程的问题,begin和end之间具体能放那些东西_百度...

oracle存储过程中,begin和end中存放的存储过程的主体。Oracle存储过程基本语法 存储过程:CREATE OR REPLACE PROCEDURE 存储过程名 IS BEGIN NULL; END;行1:CREATE OR REPLACE PROCEDURE 是一个SQL语句通知Oracle数据库去创建一个叫做skeleton存储过程, 如果存在就覆盖它;行2:IS关键词表明后面将跟随一个PL...

oracle存储过程怎么写循环

1、第一步,编写存储过程的整体结构,然后定义变量,见下图。2、其次,完成上述步骤后,在定义变量后定义游标,begin,select sysdate into v_date from dual,end test_proc,如下图所示。3、接着,完成上述步骤后,写一个for循环,游标开始for循环,为临时变量名任意起个名,输出一个字段,使用变量...

oracle存储过程的基本语法及注意事项

BEGIN END 存储过程名字 SELECT INTO STATEMENT 将select查询的结果存入到变量中 可以同时将多个列存储多个变量中 必须有一条 记录 否则抛出异常(如果没有记录抛出NO_DATA_FOUND)例子 BEGIN SELECT col col into 变量 变量 FROM typestruct where xxx;EXCEPTION WHEN NO_DATA_FOUND THEN xxxx;END;IF ...

Oracle 的存储过程怎么写。?

oracle 存储过程的基本语法 1.基本结构 CREATE OR REPLACE PROCEDURE 存储过程名字 (参数1 IN NUMBER,参数2 IN NUMBER ) IS 变量1 INTEGER :=0;变量2 DATE;BEGIN END 存储过程名字 2.SELECT INTO STATEMENT 将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条 记录,否则...

oracle中declare begin end 这样的用法叫什么语句?它和直接写select那种...

如果没有返回值就是函数,如果有返回值,就是存储过程。存储过程是编译后存在数据库里面的。只能说是在command里面编译。就是用begin end界定一个代码块,跟C语言中的{}是同一个意思。比如CREATE Procedure()as begin 。。。/ if ()begin ...end else begin ...end / end 而这里省略号位置如果...

oracle中如何得到执行存储过程的开始和结束时间

需要在存储过程中定义的时候把开始执行时间和结束时间打印出来。举例如下:创建存储过程:create or replace procedure p_testasv_begintime varchar2(20);v_endtime varchar2(20);v_str varchar2(10);begin v_begintime:=to_char(sysdate,'yyyy-mm-dd hh24:mi:ss'); select 'badkano' into...

Oracle 存储过程begin oracle存储过程loop oracle存储过程while oracle存储过程update oracle 存储过程 if oracle begin end oracle存储过程详解 oracle存储过程在哪 oracle存储过程实例
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
祭祖的背上可以开刀吗? 玉龙雪山索道平台海拔 玉龙雪山坐哪个索道 玉龙雪山哪个索道好 如何在ps中更改字体描边的颜色和大小? ps字体怎么描边去除内部颜色ps怎么去掉字体颜色 锦字取名的寓意男孩,五行属金男孩取名的字 与文章离婚八个多月,马伊琍做的5件事,给离婚女人指出了什么明路?_百度... 文章马伊琍哪一年离婚发微博 BBA太阳辐射模拟系统 河南都有哪些旅游景点。具体门票是多少? 五月河南旅游有哪些景点是必去的 河南有什么旅游景区 王者荣耀孙尚香末日机甲宣传动画怎么打开 债券市场体现了流动性和收益性的统一 怎么理解 王者荣耀孙尚香新皮肤沉稳之力值得入手吗 孙尚 漯河十大著名旅游景点 漯河有什么著名景 我对债券市场的认识是一个盲区?和股票市场有相似性吗? 孙尚香的沉稳之力会优化吗 王者荣耀孙尚香新皮肤沉稳之力值得入手吗 我想找个心理医生问问 我是怎么回事 孙尚香新皮肤可以赠送给别人嘛 请结合我国目前债券市场,阐述你对国债概念的认识,并说明你对投资于债券市场的看法 中山市哪里有心理咨询服务? 《王者荣耀》孙尚香双生皮肤正式出炉,这有受到玩家的喜欢吗? 沈阳市哪有好的心理诊所或咨询中心?要亲身经历过的(不要复制) 王者荣耀孙尚香皮肤沉稳怎么领取 泉州河市有哪里好玩的地方 惠阳淡水有没有心理医生? 王者荣耀获得新皮肤怎么炫耀皮肤视频? 天涯明月刀怎么退出帮派 天涯明月刀怎么返回,但不退出游戏。 天涯明月刀怎么退出全屏模式 天涯明月刀万里杀怎么退出帮派 请问营运车辆转为非营运车辆的年限是多少年? 天涯明月刀里帮主怎么退出帮派? 天涯明月刀ol退出位面 天涯明月刀剧情可以跳过吗?怎么跳剧情 天涯明月刀点进帮帮精灵光标不见了,怎么退出 天涯明月刀怎样退出话本 天刀助手怎么退出群聊天室? 2016款卡罗拉双擎营转非,可以在泉州过户,能开几年 天涯明月刀进入游戏剧情怎么快进退出 天涯明月刀侠客岛别苑升级中能退出游戏吗 天涯明月刀投票活动怎么退出登录 天刀怎么退出家园位面啊?用家园界面按钮进去家园位面之后出不来了,只能卡图吗 失信被执行人可以转让股权吗 天涯明月刀怎么退出选盟会 天涯明月刀怎么强制退剧情副本 营转非的车能开几年。?