菜鸟学JDBC(六)

上一篇( http://blog.csdn.net/rowandjj/article/details/8978108)我们介绍了JDBC中事务处理的知识,我们的重点是掌握事务处理的特性(ACID),以及JDBC事务处理的一般步骤,
(判断数据库是否支持事务->取消事务自动提交->添加事务信息->提交事务->异常处理,出错回滚等)。重点掌握setAutoCommit,commit,rollback等方法。
本篇我们来介绍一下JDBC中的批处理:
当需要向数据库发送一批sql语句执行时,应避免向数据库一条条的发送执行,而应该采用jdbc的批处理,可以提升执行效率.
通过addBatch()方法可以向数据库中加入多条数据,可以删除数据,同时可以执行多条记录,在向sql提交语句的时候要用executeBatch,提交之后清除缓存可以调用clearBatch方法。
看个例子:
package demo;
import java.sql.Connection;
import java.sql.Date;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class BatchDemo
{
    /**
     * 批处理sql语句
     * @param args
     */
    public static void main(String[] args)
    {
        long start = System.currentTimeMillis();
//        addBatchFunc();
        func();
        long end = System.currentTimeMillis();
        System.out.println(end - start);
    }
    public static void addBatchFunc()
    {
        Connection conn = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        try
        {
            conn = JDBCUtils.getConnection();
            String sql = "insert into tb_6 values (?,?,?)";
            ps = conn.prepareStatement(sql);
            for(int i = 0; i < 100 ; i++)
            {
                ps.setString(1,"name " + i);
                ps.setDate(2, new Date(System.currentTimeMillis()));
                ps.setFloat(3,i + 100);
                ps.addBatch();//添加批处理语句
            }
            ps.executeBatch();//执行批处理语句
            ps.clearBatch();
        }
        catch (SQLException e)
        {
            e.printStackTrace();
        }
        finally
        {
            JDBCUtils.free(rs, ps, conn);
        }
    }
    public static void func()
    {
        Connection conn = null;
        Statement st = null;
        ResultSet rs = null;
        try
        {
            conn = JDBCUtils.getConnection();
            String sql = "insert into tb_6 values ('zh','1999.10.01','1')";
            st = conn.createStatement();
            st.addBatch(sql);
            sql = "insert into tb_6 values ('ch','1999.10.01','2')";
            st.addBatch(sql);
            st.executeBatch();
            st.clearBatch();

        }
        catch (SQLException e)
        {
            e.printStackTrace();
        }
        finally
        {
            JDBCUtils.free(rs, st, conn);
        }
    }
} 

批处理比较简单,相信大家看了就知道了。

你可能感兴趣的:(菜鸟学JDBC(六))