JDBC (二)
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 (二)的更多相关文章
- JAVA基础-JDBC二(常用的开源工具)
一.连接池 在实际的开发应用中,我们常常会对数据库进行大量的高并发的访问,而最原始的连接和操作方式并不能满足这种大量的访问,程序员为了追求更方便.更快捷.更科学安全的开发.第三方的工具类和Dao层的框 ...
- JDBC二查询(web基础学习笔记八)
一.建立数据库 --创建news表空间 CREATE TABLESPACE tbs_news DATAFILE 'F:\ORACLE\news.dbf' SIZE 10M AUTOEXTEND ON; ...
- JDBC二部曲之_入门
JDBC 1 什么是JDBC? JDBC(Java DataBase Connectivity),即Java数据库连接!也就是说,Java程序员可以使用JDBC API来操作数据库. 最早JDBC是J ...
- java JDBC (二) 防止注入/参数化
package cn.sasa.demo2; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Pr ...
- java基础之JDBC二:原生代码基础应用
JDBC的基础应用CURD: 增删改 public void noQuery() { Connection conn = null; Statement stat = null; try { //注册 ...
- JDBC二部曲之_事物、连接池
事务 事务概述 事务的四大特性(ACID) 事务的四大特性是: l 原子性(Atomicity):事务中所有操作是不可再分割的原子单位.事务中所有操作要么全部执行成功,要么全部执行失败. l 一致 ...
- JDBC(二)
## 详解JDBC各个对象 1.DriverManager对象:驱动管理对象 * 功能: 1.注册驱动:告诉程序该使用哪个数据jar包 static void registerDriver(D ...
- mysql的jdbc入门学习小结
转自:专注JavaWeb开发 http://www.javaweb1024.com/data/MySQL/2015/04/25/618.html 一.jdbc基本概念jdbc : Java Datab ...
- Java基础 JDBC
一,前言 数据库是开发中必不可少的一个工具,那么java如何操作数据库呢,那就是我们的JDBC了,接下来我们将会好好聊一下这个JDBC. 二,JDBC 2.1 JDBC概述 JDBC(Java Dat ...
- JDBC(3):PreparedStatement对象介绍
一,PreparedStatement介绍 PreperedStatement是Statement的子类,它的实例对象可以通过Connection.preparedStatement()方法获得,相对 ...
随机推荐
- VS2015配置内核WDK7600环境,32位下.
VS2015配置内核WDK7600环境,32位下. 学习内核驱动的编写,就要会配置环境.不然总是用记事本编写.比较不方便. 环境配置如下. 1.首先下载WDK7600, 课堂资料代码中已经上传.链接: ...
- H5数飞机
当时进入民航大培训前做过一系列的测试,一共是8个小游戏,主要测试情景意识.反应能力.场面控制之类的,有几个还记忆犹新,这个数飞机只是其中之一,今天没事用JavaScript做了一遍. 原理 逻辑比较简 ...
- ARM非对齐操作异常解决过程
在测试MF固件时,发生一个非常诡异的异常,代码如下: CLR_DBG_Commands::Monitor_EraseMemory* cmd = (CLR_DBG_Commands::Monitor_E ...
- JAVA进阶--ThreadPoolExecutor机制
ThreadPoolExecutor机制 一.概述 1.ThreadPoolExecutor作为java.util.concurrent包对外提供基础实现,以内部线程池的形式对外提供管理任务执行,线程 ...
- ubuntu16中遇到libgstreamer-0.10.so.0缺失解决方案
1. error while loading shared libraries: libgstreamer-0.10.so.0: cannot open shared object file: No ...
- jQuery实现跨域请求实例
首先准备两个项目做测试(jsonp1,jsonp2) 一:在jsonp1中做一个用于测试的链接 def ajax(request): callbacks = request.GET.get(" ...
- And Then There Was One(约瑟夫问题变形)
题目链接:http://poj.org/problem?id=3517 And Then There Was One Time Limit: 5000MS Memory Limit: 65536K ...
- MYSQL数据库增量备份
MySQL数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可.接下来是我参考了下网上的一些方法,自己写的,主要还是要能学到他的一些思路和方法. #fu ...
- 使用npm install报错-4048 operation not permitted解决
刚刚使用npm install时一直报错-4048 operation not permitted,也尝试了多种方法,终于使问题得到解决,这里总结几种方法,先贴图: 一:权限问题 首先看到operat ...
- vue实现侧边栏手风琴效果
模板 代码如下 html <template> <div class="header"> <ul> <!-- 循环数据在点击调用chang ...