define:

  存储过程(Stored Procedure )是一组为了完成特定功能的SQL 语句 集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。存储过程是由流控制和SQL 语句书写的过程,这个过程经编译和优化后 存储在数据库服务器中,应用程序使用时只要调用即可。在ORACLE 中,若干个有联系的过程可以组合在一起构成程序包。

advantage:

1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
2.当对数据库进行复杂操作时(如对多个表进行Update、Insert、Query、Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
3.stored procedure can  be used  many times  to reduce database  developer work task.
4.high safety,set a user to use specify stored procedure )可设定只有某用户才具有对指定存储过程的使用权。

1.basic syntax

create [or replace] procedure pro_name [parameter1[,parameter2]] is|as

begin

plsql_sentences;

[exception]

[dowith_sentences;]

end [pro_name];

note: bracket [] represent  can ignore, | represent need option either is or as.

2.exercise

1.compile

create or replace procedure pro_insertDept is
 begin
     insert into dept values(90,'market','fuzhou');
      commit;
      dbms_output.put_line('insert into successfully');
end pro_insertDept;
 /ou

note: if you come out a error can use show error command;

2.execute

preface:you should lauch result print out in following sentence.

set serveout on

next:you can use the below sentences execute procedure.

execute[exec] pro_insertDept;

3.invoking procedure in pl/sql program block.

begin

  pro_insertDept;

end;

3.stored parameter

1.Stroed procedure patameter contain  in,out ,in out  three variety model.

a.in model (default model)  example in the following code

CREAET OR REPLACE PROCEDURE pro_insertDept(
num_deptno in number,
var_ename in varchar2,
var_loc in varchar2
) AS
BEGIN
INSERT INTO dept VALUES(num_deptno,var_ename,var_loc);
commit;
END pro_insertDept;
/
begin
pro_insertDept(var_ename=>'purchase',num_deptno => ,var_loc => 'fz');
-- Open the cursor and loop through the records
FOR v_rec IN (SELECT deptno, dname,loc FROM dept) LOOP
-- Print the foo and bar values
dbms_output.put_line('deptno=' || v_rec.deptno || ', dname=' || v_rec.dname||',loc='||v_rec.loc);
END LOOP;
end;
begin
    pro_insertDept(31,'sal','xm');
       -- Open the cursor and loop through the records
       FOR v_rec IN (SELECT deptno, dname,loc FROM dept) LOOP       
       -- Print the foo and bar values
       dbms_output.put_line('deptno=' || v_rec.deptno || ', dname=' || v_rec.dname||',loc='||v_rec.loc);
       END LOOP;
end;
begin
    pro_insertDept(31,var_ename=>'mainten','xm');
       -- Open the cursor and loop through the records
       FOR v_rec IN (SELECT deptno, dname,loc FROM dept) LOOP       
       -- Print the foo and bar values
       dbms_output.put_line('deptno=' || v_rec.deptno || ', dname=' || v_rec.dname||',loc='||v_rec.loc);
       END LOOP;
end;
 

1.note

         in is input parameter type.

1.specify name passing parameter with in model  is disorder.

advantage:understand meaning when you look at the codeing

disadvantage:if insert data a large number and you have a lot of work

2.follow the location passing parameter is order

a.if you forget parameter order can use desc keword.

3.meger passing patameter.

a.if you use specify name passing parameter pass values.after coding use the same method,also.because specify name passing parameter has a order.

b.out model

create or replace procedure select_dept(
num_deptno in number,--定义in模式变量,要求输入部门编号
var_dname out dept.dname%type,--定义out模式变量,可以存储部门名称并输出
var_loc out dept.loc%type) is
begin
select dname,loc
into var_dname,var_loc
from dept
where deptno = num_deptno;--检索某个部门编号的部门信息
exception
when no_data_found then --若select语句无返回记录
dbms_output.put_line('该部门编号的不存在');--输出信息
end select_dept;
/
DECLARE
var_dname dept.dname%type;
var_loc dept.loc%type;
BEGIN
select_dept(,var_dname,var_loc);
DBMS_OUTPUT.PUT_LINE('dept name is:'||var_dname||',location is:'||var_loc);
END;

variable var_dname varchar2(50);
variable var_loc varchar2(50);
execute select_dept(15,:var_dname,:var_loc);
if you not display result then can use below sentences
  1.print var_dname var_loc;
  2.select :var_danme,:var_loc from dua;

summary:

  out is a output paramter type.

  step:

    1.create procedure.

    2.define declare variable type in pl/sql block,in order to incept out values.

    3.call stored procedure incept return value in out parameter.

  note:you need define variable in out model otherwise show error give you in the progarm.

c.in out model

in out model is input parameter as well as output parameter.

oracle_procedure的更多相关文章

随机推荐

  1. 补档 Codeblocks下的文件标题栏(标签)显示方法

    可能在以下链接也能看到这篇文档 我知道很多人都不知道这个到底叫啥,还不如直接一点: 文件标题栏 就是如下的效果. 解决办法: 在左上角第三个view下,打开后取消Hide editor tabs 选项 ...

  2. Scrapy安装指南(windows)

    windows开发,难免遇到很多坑,比一般开发是艰苦得多.先不吐槽windows,我们直接看这个scrapy怎么安装. 首先,要有一份文档,比如我用这个: http://scrapy-chs.read ...

  3. Robot Framework变量的使用技巧

    1.变量的使用 变量可以在命令行中设置,个别变量设置使用--variable (-v)选项,变量文件的选择使用--variablefile (-V)选项.通过命令行设置的变量是全局变量,对其所有执行的 ...

  4. PIE SDK与Python结合说明文档

    1.功能简介 Python是一种跨平台语言.无论是在Windows.Linux.Unix还是Mac Os系统,我们都可以使用Python.甚至在Linux.Unix及Mac OS系统内已经集成了Pyt ...

  5. java se系列(三) 顺序语句、if...else、switch、While、do-while、for、break、continue

    1 顺序语句 语句:使用分号分隔的代码称作为一个语句. 注意:没有写任何代码只是一个分号的时候,也是一条语句,称作空语句. 顺序语句就是按照从上往下的顺序执行的语句. 2 判断(if…else) 什么 ...

  6. Gradle发布项目到 maven 之gradle-bintray-plugin(2)

    上传的方式有两种,第一种是通过 bintray 官方出的插件 bintray/gradle-bintray-plugin 第二种是一个国外组织开源的插件 novoda/bintray-release ...

  7. Manacher算法(马拉车)

    学习博客:https://www.cnblogs.com/love-yh/p/7072161.html 首先,得先了解什么是回文串(我之前就不是很了解,汗).回文串就是正反读起来就是一样的,如“abb ...

  8. Json化数据-调微信接口

    // 先获取用户openid列表 List<String> openids = wxPhotoUpload.getUserOpenIdList(access_token); TreeMap ...

  9. java中创建User Libray

    第一步:右键项目==>Build Path ==>Configure Build Path... 第二步:选择Libraries==>点击 Add Library.. 第三步:选择U ...

  10. python中时间对象生成及时间格式的转换

    1.将字符串的时间转换为时间戳 方法: a = "2013-10-10 23:40:00" 将其转换为时间数组 import time timeArray = time.strpt ...