1.数据库存储过程:简单滴说,存储过程就是存储在数据库中的一个程序。

2..数据库存储过程作用:

第一:存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快。

  1. 第二:存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。
  2. 第三:存储过程运行比较稳定,不会有太多的错误。只要一次成功,以后都会按这个程序运行。
  3. 第四:存储过程主要是在服务器上运行,减少对客户机的压力。
  4. 第五:存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。
  5. 第六:存储过程可以在单个存储过程中执行一系列   SQL   语句。
  6. 第七:存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。
  7. 此外,如果多条SQL语句执行过程中,过程环节返回了数据作为后面环节的输入数据,如果直接通过
  8. SQL语句执行,势必导致大量的数据通过网络返回到客户机,并在客户机运算;如果封装在存储过程中,
  9. 则将运算放在服务器进行,不但减少了客户机的压力,同时也减少了网络流量,提高了执行的效率。

3.mysql存储过程:

MySQL5存储过程,用得人好像不多。按照数据库设计原理来讲,存储过程是在db server上预编译的,所以查询速度会比较起纯SQL语句快很多。可能是现在流行OO,导至存储过程使用的余地大打折扣。但如果从效果上来讲,用存储过程来实现业务规则所带得DB SERVER压力,比用JAVA类实现业务规则所带来的WEB SERVER压力要小。当然存储过程也不应滥用,象普通的insert、update之类的语句就不需要使用存储过程了。

好了,言归正传。MySQL创建procudure的语法与sql server/Oracle差别较大。
例1:传入参数的procedure

create procedure usp_test(param varchar(20)
  select * from talbeName where column=param

例2:更新表的procedure

create procedure usp_test2 (t varchar(20))
  begin
    set xname = 'test';
    update table set column = xname where column1=t;
 end

MySQL创建存储过程时不带as,而且()不能省略,即便是没有传入参数。这一点象sql server或是oracle那样直观,而且声明变量时直接用declare,不用加的@或@@(in out变量除外)。还有一点是很怪的语法,如果是以“select”为开头的存储过程,是不能加"begin end"的。"begin end"表示多条SQL语句的复合体。

当然,事实上几乎没有哪款数据库是完全符合SQL3标准的,多少都含有自己的一些成份里面,这也造成使用存储过程会使程序的可移性降低。

调用procedure
   MySQL使用call关键字。例:call usp_test('test');而不是execute,同样()是不能省略的。
  创建完procedure后,再看看java是如何调用procedure的。
    Connection conn = null;

  1. CallableStatement cstmt = null;
  2. ResultSet rs = null;
  3. try{
  4. conn = DbConn.getDbConn();//get pool conn
  5. CallableStatement cstmt = conn.prepareCall("{call usp_test(?)}");
  6. call.setString(1, "test");
  7. rs = call.executeQuery();
  8. while(rs.next()){
  9. String te = rs.getString(1);
  10. System.out.println("te:"+te);
  11. }
  12. }catch(Exception e){
  13. System.out.println("e: "+e);
  14. }finally{
  15. try{
  16. rs.close();
  17. cstmt.close();
  18. conn.close();
  19. }catch(Exception ex){
  20. System.out.println("ex:"+ex);
  21. }
  22. }

这里使用的是"{call usp_test()}"来调用存储过程。同时也可以编程传入参数,进行查询。
    上述方法有个致命的缺点,就是传入的参数是由编写存储过程决定的。也就是说不支持象PreparedStatement那样的多参数动态查询。

下面先讲解MySQL存储过程的输入输出参数应用。例子可以直接copy运行。
    1.输入参数(也是默认参数)
     CREATE PROCEDURE usp1(IN p INT)
     BEGIN
         SET @x = p;
     END;
     call usp1(123456);
     select @x
     返回结果为 123456
    2.输出参数(out)
     CREATE PROCEDURE usp2 (OUT p int, IN p2 int)
     BEGIN
        SET p = -5 + p2;
     END
     call p6(@y,10)
     select @y
     返回结果为 5
    3.输入输出参数(inout)

CREATE PROCEDURE demoSp(IN inputParam VARCHAR(255), INOUT inOutParam INT)
BEGIN
    SET inOutParam = 1000;
    SELECT inOutParam;
    SELECT CONCAT('zyxw ', inputParam);
END
 

call demoSP(' test',@q)
     返回结果"zyxw  test"。

MySQL调用存储过程的语法讲完了,总结一下就是三个参数关键值IN、OUT、INOUT,分别代表输入参数、输出参数、输入输出参数。下面就讲解是JAVA是如何调用带有输出参数的存储过程。
    先创建一个带输出参数的Procedure

CREATE PROCEDURE demoSp(OUT inOutParam varchar(50))
BEGIN
set inOutParam = "hello procedure";
END

然后在java中调用。

            CallableStatement cstmt =  conn.prepareCall("{call demoSp(?)}");
            cstmt.registerOutParameter(1, java.sql.Types.VARCHAR);

            boolean i = cstmt.execute();

String x = cstmt.getString(1);
            System.out.println("call result:"+i+x);

很明显与没有输出参数的存储过程相比,多一个registerOutParameter。
也就是说要先注册输出参数的类型,再执行execute(),最后取回车出参数的值。
这个过程是不能颠倒的。

mysql存储过程讲解的更多相关文章

  1. 转载:mysql存储过程讲解

    记录MYSQL存储过程中的关键语法: DELIMITER // 声明语句结束符,用于区分; CEATE PROCEDURE demo_in_parameter(IN p_in int) 声明存储过程 ...

  2. mysql存储过程详细讲解及完整实例下载

    一.存储过程概念 1.存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集.经编译后存储在数据库 中. 2.存储过程是数据库中的一个重要对象,用户通过指定存储过程的名字并给 ...

  3. mysql存储过程详解

    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的S ...

  4. mysql存储过程详细教程

    记录mysql存储过程中的关键语法:DELIMITER //  声明语句结束符,用于区分;CREATE PROCEDURE demo_in_parameter(IN p_in int)  声明存储过程 ...

  5. Mysql存储过程总结

    1.     关于MySQL的存储过程 存储过程是数据库存储的一个重要的功能,但是MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.好在MySQL 5.0终于开始已经支持存储过 ...

  6. mysql 存储过程详解 存储过程

    mysql存储过程详解 1.      存储过程简介         我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成 ...

  7. MySQL存储过程详解 mysql 存储过程

    原文地址:MySQL存储过程详解  mysql 存储过程作者:王者佳暮 mysql存储过程详解 1.     存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储 ...

  8. MySQL存储过程详解 mysql 存储过程(二)

    mysql存储过程详解 1.      存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL ...

  9. mysql存储过程详解[转]

    1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储 ...

随机推荐

  1. 用 jQuery Masonry 插件创建瀑布流式的页面(转)

    瀑布流式的页面,最早我是在国外的一个叫 Pinterest 的网站上看到,这个网站爆发,后来国内的很多网站也使用了这种瀑布流方式来展示页面(我不太喜欢瀑布流这个名字). 我们可以使用 jQuery 的 ...

  2. java_TreeSet 定制排序实例

    package ming; import java.util.Comparator; import java.util.TreeSet; class M { int age; public M(int ...

  3. java_jdbc_可滚动结果集与分页

    public static void create2(int i) { Connection conn = null; Statement st = null; ResultSet rs = null ...

  4. 浅谈iOS中的视图优化

    引言: 让我们来思考几个问题,你开发过的产品,它还有可以优化的地方吗?能增加它的帧率吗?能减少多余的CPU计算吗?是不是存在多余的GPU渲染?业务这点工作量对于越来越强大的设备面前显得微不足道,但作为 ...

  5. Hibernate中的"Repeated column in mapping for entity"异常

    转:http://lijiejava.iteye.com/blog/786535 一对多双向关联(类Item与类Bid): Item类: public class Item { private int ...

  6. jQuery的自定义事件——滚轮

    这个案例类似于在地图上滚动滚轮,能缩小或者放大地图,分别用zoomIn和zoomOut来命名. 代码如下: //JS部分:<script src="jquery-1.10.2.min. ...

  7. php验证码制作

    目标: 使用php生成验证码 成品: 逻辑代码: authcode.php <?php header("Content-type:image/png"); session_s ...

  8. 业界最有价值的 ASP.NET 博文汇总

    ASP.NET凭借它丰富的控件,强大的适应性及良好的封装性,成为业界开发的一门巨匠,它大大缩短了网站开发的时间,降低开发成本.并且可以运行在Web应用软件开发者的全部平台上.本电子书汇集了业界最有价值 ...

  9. 记工作中的git遇到的问题

    看了 git 回退到某版本后,再在此版本上更新,无法push 操作前,我备份了修改了目录,准备建一个分支进行操作 我在本地revert了一次,commit到了远程仓库.然后上个版本的修改给恢复了... ...

  10. php pdo oracle中文乱码

    在/etc/profile.d/简历oracle.sh 内容如下在NLS_LANG设置编码 ORACLE_HOME=/usr/lib/oracle/12.1/client64 C_INCLUDE_PA ...