什么是存储过程:
存储过程
是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,
用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
二、为什么要用存储过程呢?
存储过程真的那么重要吗,它到底有什么好处呢?存储过程说白了就是一堆SQL 的合并。中间加了点逻辑控制。
1.存储过程处理比较复杂的业务时比较实用。具体分为两个方面:
(一)响应时间上来说有
优势:如果你在前台处理的话。可能会涉及到多次数据库连接。但如果你用存储过程的话,就只有一次。存储过程可以给我们带来运行效率提高的好处;
(二)、从安全上使用了存储过程的系统更加稳定:程序容易出现BUG 不稳定,而存储过程,只要数据库不出现问题,基本上是不会出现什么问题的。
2.数据量小的项目不用存储过程也可以正常运作。
三、那么什么时候才需要用存储过程?
存储过程不仅仅适用于大型项目,对于中小型项目,使用存储过程也是非常有必要的。

第一:存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快。
第二:存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。
第三:存储过程运行比较稳定,不会有太多的错误。只要一次成功,以后都会按这个程序运行。
第四:存储过程主要是在服务器上运行,减少对客户机的压力。
第五:存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。
第六:存储过程可以在单个存储过程中执行一系列 SQL 语句。
第七:存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。

其实存储过程还可以控制权限,比如一个表不直接允许用户直接访问,但要求允许用户访问和修改其中一个或多个字段,那就可以通过一个存储过程来实现并允许该用户使用该存储过程。

还有,如果多条SQL语句执行过程中,过程环节返回了数据作为后面环节的输入数据,如果直接通过SQL语句执行,势必导致大量的数据通过网络返回到客户机,并在客户机运算;如果封装在存储过程中,则将运算放在服务器进行,不但减少了客户机的压力,同时也减少了网络流量,提高了执行的效率。

缺点如下:
1.可维护性比较差。
2.可读性差。

个人认为在开发系统时存储过程不要滥用,用多了后期维护就比较麻烦了。

简单入门案例:

--oracle 存储过程 如下
-- 1.创建表
create table t1(id number,tname varchar2(30));
--基本格式  语法
CREATE procedure 存储过程名  AS
  BEGIN
    --执行的内容 
END;


--1、创建无参存储过程  通过 储过程添加数据
CREATE procedure insert_t1 as
begin
  insert into t1 values(1,'javacto.taobao.com');
end;

--1.调用无能存储过程
call insert_t1();
--3.查询t1表数据 
select * from t1;



--4创建带参的 存储过程  通过 储过程添加数据
CREATE procedure insert_t2(id number,tname varchar2) as
begin
  insert into t1 values(id,tname);
end;
--调用 有能的 存储过程 
call insert_t2(3,'javacto.ke.qq.com');