java使用存储过程

//(1)导入jar并加载驱动

Class.forName("com.mysql.jdbc.Driver");

//(2)获取连接

Connection connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/mytest","root","root");

(3)调用存储过程---PrepareStatement,Statement

CallableStatement callableStatement=connection.prepareCall("CALL selectUser()");//预编译sql语句

(1)通过execute执行

callableStatement.execute();

//获取结果集

ResultSet resultSet=callableStatement.getResultSet();

 

//(2)通过executeQuery执行

//取得结果集的每一行数据

ResultSet resultSet = callableStatement.executeQuery();

一、  使用jdbc进行批处理

什么是批处理?为什么需要批处理

当需要向数据库发送一批SQL语句执行时,应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率。

如何实现批处理

Statement

优缺点:

缺点:Statement,没有预编译

优点:能批处理不同Sql语句

package com.bdjg.test02;

 

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.SQLException;

import java.sql.Statement;

 

public class TestMain2 {

 

         public static void main(String[] args) {

                   // TODO Auto-generated method stub

                   try {

                            Long startTime=System.currentTimeMillis();

                            //(1)导入jar并加载驱动

                            Class.forName("com.mysql.jdbc.Driver");

                            //(2)获取连接

                            Connection connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/mytest","root","root");

                            //(3)四句语句,增加数据,修改数据,删除数据

                            String sql1="insert into user values(null,'admin','123456')";

                            String sql2="update user set uname='ADMIN' where uname='admin'";

                            String sql3="insert into user values(null,'admin2','123456')";

                            String sql4="delete from user where uname='zhangsan'";

                            //(4)获取Statement

                            Statement statement=connection.createStatement();

                            //(5)批处理去执行

                            statement.addBatch(sql1);

                            statement.addBatch(sql2);

                            statement.addBatch(sql3);

                            statement.addBatch(sql4);

                            //执行

                            statement.executeBatch();

                            //清除批处理操作

                            statement.clearBatch();

                            Long endTime=System.currentTimeMillis();

                            System.out.println("执行时间:"+(endTime-startTime));

                   } catch (Exception e) {

                            // TODO Auto-generated catch block

                            e.printStackTrace();

                   }

         }

 

}

PrepareStatement

优缺点:

缺点:只能批处理同一种sql语句

优点:预编译

package com.bdjg.test02;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.SQLException;

import java.sql.Statement;

public class TestMain3 {

//使用PrepareStatement实现批处理

       public static void main(String[] args) {

              // TODO Auto-generated method stub

              try {

                     Long startTime=System.currentTimeMillis();

                     //(1)导入jar并加载驱动

                     Class.forName("com.mysql.jdbc.Driver");

                     //(2)获取连接

                     Connection connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/mytest","root","root");

                     //(3)四句语句,增加数据,修改数据,删除数据

                     String sql="insert into user values(null,?,?)";

                     //(4)获取Statement

                     PreparedStatement preparedStatement=connection.prepareStatement(sql);

                     //(5)插入100条数据

                     for(int i=1;i<100;i++){//100遍循环,每次循环设置参数

                            preparedStatement.setObject(1, "admin"+i);

                            preparedStatement.setObject(2,"admin"+i);

                            preparedStatement.addBatch();//添加      

                            preparedStatement.clearBatch();//清除批处理

                     }

                     preparedStatement.executeBatch();//执行批处理

             

                     Long endTime=System.currentTimeMillis();//获取当前毫秒数

                     System.out.println("执行时间:"+(endTime-startTime));//获得当前的时间

              } catch (Exception e) {

                     // TODO Auto-generated catch block

                     e.printStackTrace();

              }

       }

 

}

上一篇:JDBC快速入门


下一篇:jdbc的登录案例