- Java 和 MySQL 教程
- Java 和 MySQL - 主页
- Java 和 MySQL - 概述
- Java 和 MySQL - 环境设置
- Java 和 MySQL - 示例代码
- Java 和 MySQL - 连接
- Java 和 MySQL - 异常
- Java 和 MySQL 语句
- Java 和 MySQL - 声明
- Java 和 MySQL - 准备语句
- Java 和 MySQL - CallableStatement
- Java 和 MySQL 结果
- Java 和 MySQL - 结果集
- Java 和 MySQL - 导航结果集
- Java 和 MySQL - 查看结果集
- Java 和 MySQL - 更新结果集
- Java 和 MySQL 事务
- Java 和 MySQL - 事务
- Java 和 MySQL - 提交和回滚
- Java 和 MySQL - SavePoint 事务
- Java 和 MySQL 批处理
- Java 和 MySQL - 批处理
- 批处理 - 语句
- 批处理-PreparedStatement
- Java 和 MySQL 流
- Java 和 MySQL - 流数据
- Java 和 MySQL 示例
- Java 和 MySQL - 创建数据库
- Java 和 MySQL - 选择数据库
- Java 和 MySQL - 删除数据库
- Java 和 MySQL - 创建表
- Java 和 MySQL - 删除表
- Java 和 MySQL - 插入记录
- Java 和 MySQL - 选择记录
- Java & MySQL - 更新记录
- Java 和 MySQL - 删除记录
- Java 和 MySQL -Where 子句
- Java 和 MySQL - Like 子句
- Java 和 MySQL - 数据排序
- Java 和 MySQL 有用资源
- Java 和 MySQL - 快速指南
- Java 和 MySQL - 有用的资源
- Java 和 MySQL - 讨论
Java 和 MySQL - 使用PrepareStatement 对象进行批处理
以下是使用带有PrepareStatement对象的批处理的典型步骤序列 -
创建带有占位符的 SQL 语句。
使用prepareStatement() 方法创建PrepareStatement 对象。
使用setAutoCommit()将自动提交设置为 false 。
使用创建的语句对象上的addBatch()方法将任意数量的 SQL 语句添加到批处理中。
使用创建的语句对象上的executeBatch()方法执行所有SQL语句。
最后,使用commit()方法提交所有更改。
该示例代码是根据前面章节中完成的环境和数据库设置编写的。
将以下示例复制并粘贴到 TestApplication.java 中,编译并运行如下 -
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class TestApplication { static final String DB_URL = "jdbc:mysql://localhost/TUTORIALSPOINT"; static final String USER = "guest"; static final String PASS = "guest123"; static final String INSERT_QUERY = "INSERT INTO Employees(first,last,age) VALUES(?, ?, ?)"; public static void printResultSet(ResultSet rs) throws SQLException{ // Ensure we start with first row rs.beforeFirst(); while(rs.next()){ // Display values System.out.print("ID: " + rs.getInt("id")); System.out.print(", Age: " + rs.getInt("age")); System.out.print(", First: " + rs.getString("first")); System.out.println(", Last: " + rs.getString("last")); } System.out.println(); } public static void main(String[] args) { // Open a connection try(Connection conn = DriverManager.getConnection(DB_URL, USER, PASS); PreparedStatement stmt = conn.prepareStatement(INSERT_QUERY, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE) ) { conn.setAutoCommit(false); ResultSet rs = stmt.executeQuery("Select * from Employees"); printResultSet(rs); // Set the variables stmt.setString( 1, "Pappu" ); stmt.setString( 2, "Singh" ); stmt.setInt( 3, 33 ); // Add it to the batch stmt.addBatch(); // Set the variables stmt.setString( 1, "Pawan" ); stmt.setString( 2, "Singh" ); stmt.setInt( 3, 31 ); // Add it to the batch stmt.addBatch(); // Create an int[] to hold returned values int[] count = stmt.executeBatch(); //Explicitly commit statements to apply changes conn.commit(); rs = stmt.executeQuery("Select * from Employees"); printResultSet(rs); stmt.close(); rs.close(); } catch (SQLException e) { e.printStackTrace(); } } }
现在让我们按如下方式编译上面的示例 -
C:\>javac TestApplication.java C:\>
当您运行TestApplication时,它会产生以下结果 -
C:\>java TestApplication ID: 1, Age: 23, First: Zara, Last: Ali ID: 2, Age: 30, First: Mahnaz, Last: Fatma ID: 3, Age: 35, First: Zaid, Last: Khan ID: 4, Age: 33, First: Sumit, Last: Mittal ID: 5, Age: 40, First: John, Last: Paul ID: 7, Age: 35, First: Sita, Last: Singh ID: 8, Age: 20, First: Rita, Last: Tez ID: 9, Age: 20, First: Sita, Last: Singh ID: 10, Age: 30, First: Zia, Last: Ali ID: 11, Age: 35, First: Raj, Last: Kumar ID: 1, Age: 23, First: Zara, Last: Ali ID: 2, Age: 30, First: Mahnaz, Last: Fatma ID: 3, Age: 35, First: Zaid, Last: Khan ID: 4, Age: 33, First: Sumit, Last: Mittal ID: 5, Age: 40, First: John, Last: Paul ID: 7, Age: 35, First: Sita, Last: Singh ID: 8, Age: 20, First: Rita, Last: Tez ID: 9, Age: 20, First: Sita, Last: Singh ID: 10, Age: 30, First: Zia, Last: Ali ID: 11, Age: 35, First: Raj, Last: Kumar ID: 12, Age: 33, First: Pappu, Last: Singh ID: 13, Age: 31, First: Pawan, Last: Singh C:\>