加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

MySQL存储过程之java调用 (带有输入和输出参数的java调用)

(2012-12-12 13:44:41)
标签:

杂谈

分类: java
 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;
    CallableStatement cstmt = null;
    ResultSet rs = null;
    try{
        conn = DbConn.getDbConn();//get pool conn
        CallableStatement cstmt = conn.prepareCall("{call usp_test(?)}");
            call.setString(1, "test");
            rs = call.executeQuery();
            while(rs.next()){
                String te = rs.getString(1);
                System.out.println("te:"+te);
            }
        }catch(Exception e){
            System.out.println("e: "+e);
        }finally{
            try{
                rs.close();
                cstmt.close();
                conn.close();
            }catch(Exception ex){
                System.out.println("ex:"+ex);
            }
        }

   这里使用的是"{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(),最后取回车出参数的值。
这个过程是不能颠倒的。

   讲完了。真累!!!!!

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有