`
lcy0202
  • 浏览: 178333 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

java 调用MySQL存储过程(转载)

 
阅读更多

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

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

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

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

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;

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

本文转于:http://blog.sina.com.cn/s/blog_4b65223901000cxb.html

分享到:
评论

相关推荐

    Java实现调用MySQL存储过程详解

    总的来说,Java通过JDBC调用MySQL存储过程涉及到连接数据库、创建`CallableStatement`、执行存储过程和处理结果。这使得开发者能够在Java应用中灵活地利用数据库提供的强大功能,实现更高效的数据处理。

    Java调用Mysql存储过程

    总之,Java调用MySQL存储过程是一个涉及JDBC、CallableStatement和数据库交互的过程。理解这些步骤并正确地应用它们,可以有效地利用存储过程提高应用程序的性能和效率。记得在实际开发中,根据实际情况调整代码,...

    Java调用数据库存储过程[mysql测试通过]

    以下是一个简单的Java调用MySQL存储过程的示例: ```java import java.sql.*; public class TestJavaProcedure { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/mydb"; ...

    Java调用存储过程--传入集合参数

    ### Java调用存储过程——传入集合参数:深入解析与实践 #### 核心知识点概览 在Java应用中,调用数据库存储过程时,往往需要处理复杂的参数传递,特别是当参数为集合类型时,这一过程变得更加具有挑战性。本文将...

    MyBatis调用MYSQL存储过程

    MyBatis调用MYSQL存储过程 返回多行 引用的包: asm-3.1.jar cglib-2.2.jar commons-logging-1.1.1.jar log4j-1.2.13.jar mybatis-3.0.4.jar mysql-connector-java-5.1.13.jar slf4j-api-1.5.8.jar slf4j-log4j12-...

    Java调用MySQL存储过程并获得返回值的方法

    总之,Java调用MySQL存储过程并获取返回值涉及到数据库连接、创建`CallableStatement`对象、设置参数、执行存储过程、处理结果集、关闭资源以及异常处理等多个环节。理解并熟练掌握这些步骤对于进行数据库驱动的Java...

    java调用存储过程(含out参数)

    在Java编程中,调用数据库的存储过程是常见的任务,特别是在处理复杂的业务逻辑或需要高效数据操作时。本文将详细讲解如何在Java中调用含有`OUT`参数的存储过程,帮助开发者解决这类问题。 首先,理解存储过程的...

    如何在java中调用mysql的存储过程的事例

    这就是在Java中调用MySQL存储过程的基本步骤。在实际开发中,你可能需要根据具体的需求进行调整,如处理多结果集、异常处理等。理解这个过程可以帮助你更有效地利用存储过程提升数据库操作的效率和安全性。

    java 调用存储过程

    值得注意的是,上述代码中的文件名列表(如Project1.cfg、Unit1.dcu等)与Java调用存储过程无关,它们看起来像是Delphi或FreePascal项目的文件,这些文件通常用于描述项目配置、单元信息、表单布局等,而不是与Java...

    JAVA通过MyBatis调用MySql存储过程和函数doc文档合集整理.zip

    这个文档合集应该详细讲解了这些步骤和最佳实践,帮助开发者熟练掌握在Java中利用MyBatis调用MySQL存储过程和函数的技巧,从而更高效地进行数据库操作。通过深入学习和实践,开发者可以更好地理解这两者之间的交互,...

    spring mvc + mybatis 调用mysql 存储过程

    本文将详细讲解如何在Spring MVC和MyBatis集成的项目中调用MySQL存储过程。 首先,让我们理解存储过程的概念。存储过程是在数据库中预编译的一组SQL语句,可以包含输入、输出和内部参数,能够执行复杂的业务逻辑。...

    struts+spring_ibaits+调用Mysql存储过程实现增删改查

    在本项目中,"struts+spring_ibaits+调用Mysql存储过程实现增删改查",意味着开发者利用这三个框架来处理数据库中的增、删、改、查(CRUD)操作,并通过调用MySQL的存储过程来实现这些功能。存储过程是预编译的SQL...

    java操作mysql存储过程的例子.doc

    本文将通过两个具体的例子来讲解如何使用Java调用MySQL的存储过程。 **例子一:** 1. 首先,我们创建一个名为`test`的表,它有一个整型字段`field1`,并插入一条数据(值为1)。 ```sql create table test(field1 ...

    mybatis调用mysql存储过程

    通过以上步骤,你已经掌握了如何在MyBatis中调用MySQL存储过程的基本方法。在实际开发中,这将极大地提升你的数据库操作效率,使你能够更好地管理和处理复杂的业务逻辑。在后续的实践中,你可以尝试结合具体业务场景...

    java调用mysql命令 导入导出数据库

    在给定的标题“java调用mysql命令 导入导出数据库”中,我们可以理解为使用Java来执行MySQL的命令行工具,如`mysqldump`和`mysql`,来实现这些功能。下面将详细讲解如何在Java程序中调用这些命令。 首先,让我们...

    mysql调用存储过程

    总之,通过JDBC调用MySQL存储过程使得Java应用程序能够灵活地与数据库交互,执行复杂的业务逻辑,同时保持代码的简洁性和可读性。这在大型系统中尤其重要,因为它允许数据库管理员在不改变应用程序代码的情况下优化...

    java调用存储过程

    Java调用存储过程是数据库操作中的常见任务,特别是在复杂的业务逻辑和数据处理中。MyEclipse作为一款强大的Java集成开发环境,提供了方便的工具来支持这一功能。下面将详细介绍如何在MyEclipse中使用Java调用存储...

    Java调用存储过程的2种方法

    ### Java调用存储过程的两种方法 在Java中调用数据库中的存储过程是常见的操作之一,这不仅可以提高程序性能和代码可维护性,还可以更好地利用数据库的功能。根据提供的标题、描述以及部分内容,本文将详细介绍Java...

    Java程序调用存储过程

    Java程序调用存储过程是数据库操作中的常见任务,特别是在处理大量数据或需要高效执行复杂业务逻辑时。存储过程是预编译的SQL语句集合,它们可以提高性能、减少网络流量,并提供更好的安全性。在Java应用程序中调用...

Global site tag (gtag.js) - Google Analytics