求助JAVA调用MYSQL存储过程的问题

发布网友

我来回答

3个回答

懂视网

com.inba.maya.cunchu; import java.util.*; import java.sql.*; public class MyCunChu { public static void main(String[] args) throws Exception{ Class.forName("com.mysql.jdbc.Driver"); Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb?characterEncoDing=GBK","root",""); //注意:在调用数据库函数时关键词是 call 函数名后一定要加(),无论该函数是不是带有参数的,带参数的话一定要写参数; //调用没有参数的 //CallableStatement cs=conn.prepareCall("call TCC()"); //ResultSet rs=cs.executeQuery(); //调用有参数的 //CallableStatement cs=conn.prepareCall("call TTA(?, ?)"); //输入两个参数 //cs.setString(1, "k006"); //cs.setInt(2, 90); //ResultSet rs=cs.executeQuery(); //输出参数 CallableStatement cs=conn.prepareCall("call TDD(?, ?)"); //在这里由于我在数据库中写参数时,定义的第一个参数是IN,第二个参数是OUT,所以第一个还是要setString cs.setString(1, "k001"); //因为第二个是OUT,所以要用registerOutParameter(位置,java.sql.Types.数据类型) cs.registerOutParameter(2, java.sql.Types.INTEGER); ResultSet rs=cs.executeQuery(); //获得参数时一定要在上面执行查询完成之后 int n=cs.getInt(2); while(rs.next()){ System.out.println(n); System.out.println(rs.getString(1)+rs.getString(2)+rs.getInt(5)+rs.getDouble(3)); } conn.close(); } }

 

用JAVA调用Mysql数据库,数据存储过程的封装与调用;

标签:throws   local   static   style   public   jdbc   --   gis   实例   

热心网友

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

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

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

第二:存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。     

第三:存储过程运行比较稳定,不会有太多的错误。只要一次成功,以后都会按这个程序运行。     

第四:存储过程主要是在服务器上运行,减少对客户机的压力。   

第五:存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。   

第六:存储过程可以在单个存储过程中执行一系列   SQL   语句。   

第七:存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。

此外,如果多条SQL语句执行过程中,过程环节返回了数据作为后面环节的输入数据,如果直接通过

SQL语句执行,势必导致大量的数据通过网络返回到客户机,并在客户机运算;如果封装在存储过程中,

则将运算放在服务器进行,不但减少了客户机的压力,同时也减少了网络流量,提高了执行的效率。


3.mysql存储过程:

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

MySQL创建procure的语法与sql server/Oracle差别较大。
例1:传入参数的procere

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

例2:更新表的procere

create procere 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标准的,多少都含有自己的一些成份里面,这也造成使用存储过程会使程序的可移性降低。

   调用procere
   MySQL使用call关键字。例:call usp_test('test');而不是execute,同样()是不能省略的。
  创建完procere后,再看看java是如何调用procere的。
    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()}"来调用存储过程。同时也可以编程传入参数,进行查询。

热心网友

书上说的太复杂了而且不易理解,楼上的复制粘贴的我看不懂估计你更看不懂,我就简单说吧:

比如我们要执行mysql中的student表,执行一条查询语句select * from student

java中写一个实体类student,包含所有student表中的所有属性,如name,age,score等

选择jdbc的数据库沟通方式,建立connection,paredstatement;

connection中写数据库名,driver名,用户名,密码;

建立String类型sqlStr中写入sql语句select * from student ,

调用parestatement的query方法将sqlStr作为参数传过去;就好了;

query方法会返回一个resultSet类型的结果集,拿到它就成功了;

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com