1 使用JDBC进行批处理

  • 当需要向数据库发送一批SQL语句的时候,应该避免向数据库一条条的发送执行,而应该采用JDBC的批处理机制,以提高执行效率。
  • 实现批处理的方式一:

    • Statement.addBatch(sql)
    • 执行批处理SQL语句:
      • executeBatch()方法:执行批处理命令。
      • clearBatch()方法:清理批处理命令。
    • 优点:可以向数据库发送多条不同的SQL语句。
    • 缺点:
      • ①SQL语句没有预编译。
      • ②当向数据库发送多条SQL语句相同,但仅仅参数不同的SQL语句的时候,需要重复写很多条SQL语句。 
  • 示例:实现批处理的方式一

    • SQL  
CREATE TABLE `user` (
  `id` ) NOT NULL AUTO_INCREMENT,
  `name` ) DEFAULT NULL,
  `password` ) DEFAULT NULL,
  `email` ) DEFAULT NULL,
  `birthday` date DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE DEFAULT CHARSET=utf8;
    • jdbc.properties  
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/jdbc
jdbc.user=root
jdbc.password=root
    • JDDCUtil.java  
package util;

import java.io.FileInputStream;
import java.io.IOException;
import java.sql.*;
import java.util.Properties;

/**
 * 2017/11/9
 * 说明:用来获取JDBC连接和释放资源的工具类
 */
public class JDBCUtil {
    private JDBCUtil(){}

    /**
     * 获取数据库的连接
     * @return
     * @throws IOException
     * @throws SQLException
     * @throws ClassNotFoundException
     */
    public static Connection getConnection() throws IOException, SQLException, ClassNotFoundException {
        Connection conn = null;
        //获取类路径下jdbc.properties的实际路径
        String jdbcPropertiesPath = JDBCUtil.class.getClassLoader().getResource("").getPath()+"jdbc.properties";
        //创建Properties对象
        Properties properties = new Properties();
        //将jdbc.properties文件加载进Properties对象
        properties.load(new FileInputStream(jdbcPropertiesPath));
        String driver = properties.getProperty("jdbc.driver");
        String url =  properties.getProperty("jdbc.url");
        String user = properties.getProperty("jdbc.user");
        String password = properties.getProperty("jdbc.password");

        //加载驱动
        Class.forName(driver);
        //获取连接
        conn = DriverManager.getConnection(url,user,password);
        return conn;
    }

    /**
     * 释放资源
     * @param conn
     * @param stmt
     * @param rs
     */
    public static void close(Connection conn, Statement stmt, ResultSet rs){
        if(conn != null){
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if(stmt != null){
            try {
                stmt.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if(rs != null){
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }

    }

}
    • DemoTest.java  
package test;

import org.junit.jupiter.api.Test;
import util.JDBCUtil;

import java.sql.Connection;
import java.sql.Statement;
import java.util.Arrays;

/**
 * 2017/11/9
 * 说明:
 */
public class DemoTest {

    @Test
    public void demo1(){
        Connection conn = null;
        Statement stmt = null;
        try {
            conn = JDBCUtil.getConnection();
            stmt = conn.createStatement();
            stmt.addBatch("insert into user values (null,'hehe','hehe','hehe@qq.com','2012-05-12')");
            stmt.addBatch("delete from user where id = 5");
            int[] is = stmt.executeBatch();
            System.out.println(Arrays.toString(is));

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            JDBCUtil.close(conn,stmt,null);
        }

    }

}
  • 实现批处理的方式二:

    • PreparedStatement.addBatch();
    • 需要注意内存问题。
    • 优点:发送的是预编译的SQL语句,执行效率高。
    • 缺点:只能应用在相同的SQL语句,但参数不同的批处理中,因此此种形式的批处理经常用于在同一个表中批量插入数据, 或批量更新表的数据。
package test;

import org.junit.jupiter.api.Test;
import util.JDBCUtil;

import java.sql.Connection;
import java.util.Date;
import java.sql.PreparedStatement;
import java.sql.Statement;
import java.util.Arrays;

/**
 * 2017/11/9
 * 说明:
 */
public class DemoTest {

    @Test
    public void demo2(){
        Connection conn = null;
        PreparedStatement pstmt = null;
        try {
            conn = JDBCUtil.getConnection();
            pstmt = conn.prepareStatement("insert into user VALUES (null,?,?,?,?)");
            for(int x =0;x<10000;x++){
               pstmt.setString(1,x+"name");
                pstmt.setString(2,x+"password");
                pstmt.setString(3,x+"email");
                pstmt.setDate(4,new java.sql.Date(new Date().getTime()));
                pstmt.addBatch();
                if(x % 1000 == 0){
                    pstmt.executeBatch();
                    pstmt.clearBatch();;
                }

            }
            pstmt.executeBatch();
            JDBCUtil.close(conn,pstmt,null);

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            JDBCUtil.close(conn,pstmt,null);
        }
    }

}

2 事务

2.1 事务的概述

  • 事务:事务是指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部失败。
  • 以MySQL为例:(默认情况下,MySQL的事务是默认开启的)
  • 开启事务的命令:
start transaction
  • 回滚事务:
rollback
  • 提交事务:
commit
  • JDBC使用事务:
  • 当jdbc程序向数据库获得一个Connection对象的时候,默认情况下Connection对象会自动向数据库提交发送的SQL。如果想关闭这种默认的提交方式,让多条SQL在同一个事务中执行,可以使用下列的语句:
  • 开启事务
void setAutoCommit(boolean autoCommit) throws SQLException
  • 回滚事务
void rollback() throws SQLException
  • 提交事务
void commit() throws SQLException

2.2 事务的特性(ACID)

  • 原子性:处于事务中的多条语句是不可分割的。
  • 一致性:事务必须使得数据库从一个一致性状态变换到另一个一致性状态。比如::转账前,A+B=10000元;转账后,A+B=10000元。
  • 隔离性:多线程并发,一个事务不能被其它线程中的事务所打扰。
  • 持久性:事务一旦提交,就永久保存起来。

2.3 事务的隔离级别

  • 多个线程开启各自的事务操作数据库中的数据的时候,数据库系统要负责隔离操作,以保证各个线程在获取数据时候的准确性。
  • 如果不考虑事务的隔离性,那么可能会引起如下的问题:
    • ①脏读:一个线程中的事务读取了另一个线程中没有提交的数据。
    • ②不可重复读:一个线程中的事务读取了另一个线程中已经提交的update的数据。
    • ③虚读(幻读):一个线程中的事务读取了另外一个线程中已经提交的insert的数据。  
  • 要避免上面的现象,可以通过更改事务的隔离级别来避免:
    • read uncommitted:脏读、不可重复读、虚读有可能发生。
    • read committed:避免脏读的发生,不可重复读和虚读有可能发生。
    • repeatable read:避免脏读和不可重复读的发生,虚读有可能发生。
    • serializable:避免脏读、不可重复读和虚读。  
  • 事务的隔离级别越大,效率越低。
  • MySQL中查询当前的隔离级别:
select @@tx_isolation;
  • MySQL中设置当前的事务的隔离级别:
set transaction isolation level 级别;

3 模拟百度分页显示效果

  • https://github.com/xuweiweiwoaini/pagination.git

JDBC (二)的更多相关文章

  1. JAVA基础-JDBC二(常用的开源工具)

    一.连接池 在实际的开发应用中,我们常常会对数据库进行大量的高并发的访问,而最原始的连接和操作方式并不能满足这种大量的访问,程序员为了追求更方便.更快捷.更科学安全的开发.第三方的工具类和Dao层的框 ...

  2. JDBC二查询(web基础学习笔记八)

    一.建立数据库 --创建news表空间 CREATE TABLESPACE tbs_news DATAFILE 'F:\ORACLE\news.dbf' SIZE 10M AUTOEXTEND ON; ...

  3. JDBC二部曲之_入门

    JDBC 1 什么是JDBC? JDBC(Java DataBase Connectivity),即Java数据库连接!也就是说,Java程序员可以使用JDBC API来操作数据库. 最早JDBC是J ...

  4. java JDBC (二) 防止注入/参数化

    package cn.sasa.demo2; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Pr ...

  5. java基础之JDBC二:原生代码基础应用

    JDBC的基础应用CURD: 增删改 public void noQuery() { Connection conn = null; Statement stat = null; try { //注册 ...

  6. JDBC二部曲之_事物、连接池

    事务 事务概述 事务的四大特性(ACID) 事务的四大特性是: l  原子性(Atomicity):事务中所有操作是不可再分割的原子单位.事务中所有操作要么全部执行成功,要么全部执行失败. l  一致 ...

  7. JDBC(二)

    ##  详解JDBC各个对象 1.DriverManager对象:驱动管理对象 *  功能: 1.注册驱动:告诉程序该使用哪个数据jar包 static  void  registerDriver(D ...

  8. mysql的jdbc入门学习小结

    转自:专注JavaWeb开发 http://www.javaweb1024.com/data/MySQL/2015/04/25/618.html 一.jdbc基本概念jdbc : Java Datab ...

  9. Java基础 JDBC

    一,前言 数据库是开发中必不可少的一个工具,那么java如何操作数据库呢,那就是我们的JDBC了,接下来我们将会好好聊一下这个JDBC. 二,JDBC 2.1 JDBC概述 JDBC(Java Dat ...

  10. JDBC(3):PreparedStatement对象介绍

    一,PreparedStatement介绍 PreperedStatement是Statement的子类,它的实例对象可以通过Connection.preparedStatement()方法获得,相对 ...

随机推荐

  1. 优雅的处理Redis访问超时

    很长一段时间以来,一直在项目中使用Redis作为辅助存储,确切来说是利用Redis的内存存储,而不是将其作为缓存.比如常见的利用Set集合来判断某个数值是否存在,或者将来自不同请求的数据放在Redis ...

  2. 一个通用的Makefile(二)

    1.各级子目录的Makefile: obj-y += file.o obj-y += subdir/ “obj-y += file.o” 表示把当前目录下的file.c编进程序里. “obj-y += ...

  3. WPF: WpfWindowToolkit 一个窗口操作库的介绍

    在 XAML 应用的开发过程中,使用MVVM 框架能够极大地提高软件的可测试性.可维护性.MVVM的核心思想是关注点分离,使得业务逻辑从 View 中分离出来到 ViewModel 以及 Model ...

  4. HUST 1585 排队

    1585 - 排队 时间限制:1秒 内存限制:128兆 351 次提交 179 次通过 题目描述 BG站在一个有n个人的队伍中,但他并不知道他处于队伍中的哪个位置,他向前向后观察,只能断定他的前方有至 ...

  5. bzoj:1575: [Usaco2009 Jan]气象牛Baric

    Description 为了研究农场的气候,Betsy帮助农夫John做了N(1 <= N <= 100)次气压测量并按顺序记录了结果M_1...M_N(1 <= M_i <= ...

  6. bzoj:1221;vijos 1552 软件开发

    Description 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员 ...

  7. hihoCoder #1053 : 居民迁移(贪心,二分搜索,google在线技术笔试模拟)

    #1053 : 居民迁移 时间限制:3000ms 单点时限:1000ms 内存限制:256MB 描述 公元2411年,人类开始在地球以外的行星建立居住点.在第1326号殖民星上,N个居住点分布在一条直 ...

  8. HDU 2079 dp解法

    选课时间(题目已修改,注意读题) Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  9. for语句,你真正搞懂了吗?

    今天看书时,无意间看到了这个知识点,啥知识点?也许在各位大神看来,那是再简单不过的东西了. 说来惭愧.原来直到今天我才真正搞懂for语句. for语句的结构如下所示: for(语句A;语句B;语句C) ...

  10. setTimeout,setInterval运行原理

      function a() { setTimeout(function(){alert(1)},0); alert(2); } a(); 和其他的编程语言一样,Javascript中的函数调用也是通 ...