存储过程

存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字
并给定参数(如果该存储过程带有参数)来调用执行它。

一个存储过程可以由SQL语句和一些特殊的控制结构组成。

存储过程的优点:
(1)存储过程可以用流程控制语言编写,可以完成复杂的判断和运算,有很强的灵活性。
(2)存储过程被创建后,可以在程序中被多次调用,而不必重新编写该存储过程的SQL语句。而且数据库
专业人员可以随时对存储过程进行修改,对应用程序源代码毫无影响。 
(3)存储过程能实现较快的执行速度。
(4)存储过程能减少网络流量。
(5)存储过程可被作为一种安全机制来充分利用。系统管理员通过对某一存储过程的权限进行控制,能够实现
对相应的数据访问权限的限制,避免了非授权用户对数据的访问,保证了数据的安全。

在MySQL5.0之前并不支持存储过程。好在5.0之后已经开始支持存储过程了,这大大提高了数据库的处理速度,
同时也可以提高数据库编程的灵活性。

MySQL存储过程创建的格式:CREATE PROCEDURE 过程名 ([过程参数[, …]]) [特性….] 过程体

mysql> DELIMITER //    
mysql> CREATE PROCEDURE proc1(OUT s int)    
    -> BEGIN   
    -> SELECT COUNT(*) INTO s FROM user;    
    -> END   
    -> //    
mysql> DELIMITER ;

1.DELIMITER是分割符的意思,因为MySQL默认以”;”为分隔符,如果我们没有声明分割符,那么编译器会把存储
过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以要事先用DELIMITER关键字申明当前段分隔
符,这样MySQL才会将”;”

2.存储过程根据需要可能会有输入、输出、输入输出参数,这里有一个输出参数s,类型是int型,如果有
多个参数用”,”分割开。

3.过程体的开始与结束使用BEGIN与END进行标识。 

(2)声明分隔符 
关于声明分割符,上面的注解已经写得很清楚,不需要多说,只是稍微要注意一点的是:如果是用MySQL
的Administrator管理工具时,可以直接创建,不再需要声明。

(3)参数 
共有三种参数类型,IN,OUT,INOUT,形式如: 
CREATE PROCEDURE([[IN |OUT |INOUT ] 参数名 数据类形…]) 
IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,
为默认值 
OUT 输出参数:该值可在存储过程内部被改变,并可返回 
INOUT 输入输出参数:调用时指定,并且可被改变和返回

mysql > DELIMITER //    
mysql > CREATE PROCEDURE demo_in_parameter(IN p_in int)    
-> BEGIN     
-> SELECT p_in;     
-> SET p_in=2;     
-> SELECT p_in;     
-> END;     
-> //    
mysql > DELIMITER ;

删除一个存储过程比较简单,和删除表一样:DROP  PROCEDURE 存储过程名

Oracle存储过程

1、什么是存储过程。存储过程是数据库服务器端的一段程序,它有两种类型。一种类似于SELECT查询,
用于检索数据,检索到的数据能够以数据集的形式返回给客户。另一种类似于INSERT或DELETE查询,它不返回
数据,只是执行一个动作。有的服务器允许同一个存储过程既可以返回数据又可以执行动作。

2、什么时候需要用存储过程
存储过程通常是一些经常要执行的任务,这些任务往往是针对大量的记录而进行的。在服务器上执行存储过程,
可以改善应用程序的性能。服务器往往具有强大的计算能力和速度。.避免把大量的数据下载到客户端,减少
网络上的传输量。

3、存储过程的参数
要执行服务器上的存储过程,往往要传递一些参数。这些参数分为四种类型:
第一种称为输入参数,由客户程序向存储过程传递值。
第二种称为输出参数,由存储过程向客户程序返回结果。
第三种称为输入/输出参数,既可以由客户程序向存储过程传递值,也可以由存储过程向客户程序返回结果。
第四种称为状态参数,由存储过程向客户程序返回错误信息。

4、oracle 存储过程的基本语法

1.基本结构

CREATE OR REPLACEPROCEDURE 存储过程名字
(
     参数1 IN NUMBER,
     参数2 IN NUMBER
 ) IS
变量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;

一:无返回值的存储过程

存储过程为:


CREATE OR REPLACE PROCEDURE TESTA(PARA1 IN VARCHAR2,PARA2 IN VARCHAR2) AS
 BEGIN 
   INSERT INTO HYQ.B_ID (I_ID,I_NAME) S (PARA1, PARA2);
 END TESTA;

 import java.sql.*;
 import java.sql.ResultSet;
 public class TestProcedureOne {
 public TestProcedureOne() {
 }
 public static void main(String[] args ){
     String driver = "oracle.jdbc.driver.OracleDriver";
     String strUrl = "jdbc:oracle:thin:@127.0.0.1:1521: hyq ";
     Statement stmt = null;
     ResultSet rs = null;
     Connection conn = null;
     CallableStatement cstmt = null;
     try {
       Class.forName(driver);
       conn = DriverManager.getConnection(strUrl, " hyq ", " hyq ");
       CallableStatement proc = null;
       proc = conn.prepareCall("{ call HYQ.TESTA(?,?) }");
       proc.setString(1, "100");
       proc.setString(2, "TestOne");
       proc.execute();
     }
     catch (SQLException ex2) {
       ex2.printStackTrace();
     }
     catch (Exception ex2) {
       ex2.printStackTrace();
     }
     finally{
       try {
         if(rs != null){
           rs.close();
           if(stmt!=null){
             stmt.close();
           }
           if(conn!=null){
             conn.close();
           }
         }
       }
       catch (SQLException ex1) {
       }
     }
 }
 }

SQL 语句需要先编译然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的 SQL 
语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)
来调用执行它。

存储过程是可编程的函数,在数据库中创建并保存,可以由 SQL 语句和控制结构组成。当想要在不同的应用
程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的。数据库中的存储过程可以看做
是对编程中面向对象方法的模拟,它允许控制数据的访问方式。

存储过程的优点:
增强 SQL 语言的功能和灵活性;
标准组件式编程;
较快的执行速度;
减少网络流量;
作为一种安全机制来充分利用。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值