
- JDBC 教程
- JDBC - 首頁
- JDBC - 簡介
- JDBC - SQL 語法
- JDBC - 環境配置
- JDBC - 示例程式碼
- JDBC - 驅動程式型別
- JDBC - 連線
- JDBC - 語句
- JDBC - 結果集
- JDBC - 資料型別
- JDBC - 事務
- JDBC - 異常
- JDBC - 批次處理
- JDBC - 儲存過程
- JDBC - 流式資料
- JDBC - RowSet
- JDBC - 複製資料庫
- JDBC - ACID 屬性
- JDBC - 連線池
- JDBC 示例
- JDBC - 建立資料庫
- JDBC - 選擇資料庫
- JDBC - 刪除資料庫
- JDBC - 建立表
- JDBC - 刪除表
- JDBC - 插入記錄
- JDBC - 查詢記錄
- JDBC - 更新記錄
- JDBC - 刪除記錄
- JDBC - WHERE 子句
- JDBC - LIKE 子句
- JDBC - 資料排序
- JDBC 有用資源
- JDBC - 問答
- JDBC - 快速指南
- JDBC - 有用資源
- JDBC - 討論
- 有用資源 - Java 教程
JDBC - 使用PreparedStatement物件的批次處理
以下是使用 PrepareStatement 物件進行批次處理的典型步驟:
建立帶有佔位符的 SQL 語句。
使用 `prepareStatement()` 方法建立 PrepareStatement 物件。
使用 `setAutoCommit()` 將自動提交設定為 false。
使用已建立的語句物件的 `addBatch()` 方法將任意數量的 SQL 語句新增到批處理中。
使用已建立的語句物件的 `executeBatch()` 方法執行所有 SQL 語句。
最後,使用 `commit()` 方法提交所有更改。
此示例程式碼是基於前面章節中完成的環境和資料庫設定編寫的。
JDBC 示例中將 PreparedStatement(INSERT)以自動提交為 False 的方式批次執行
在這個例子中,我們有三個靜態字串,包含資料庫連線 URL、使用者名稱和密碼。我們定義了一個 `printResultSet()` 方法,它以結果集作為引數,迭代並列印結果集的所有記錄。一旦所有更改提交後,`printResultSet()` 方法被呼叫以列印所有記錄。
現在使用 `DriverManager.getConnection()` 方法,我們準備了一個數據庫連線。使用 `setAutoCommit(false)`,我們將自動提交設定為 false,預設為 true。連線準備就緒後,我們使用 `connection.createPreparedStatement()` 方法建立了一個 PreparedStatement 物件,同時傳遞了一個帶有佔位符的 INSERT 查詢。然後使用 `statement.executeQuery()`,所有記錄都被提取並使用 `printResultSet()` 方法列印。
現在我們已經為 preparedStatement 設定了值,然後使用 `addBatch()` 方法將 preparedStatement 新增到批處理中。新增後,我們再次為 preparedStatement 物件設定值,並使用 `addBatch()` 方法將 preparedStatement 新增到批處理中。然後使用 `executeBatch()` 方法,我們一次性執行所有語句,並使用 `commit()` 方法提交更改。現在使用 `printResultSet()`,我們正在列印 Employees 表中可用的所有記錄。
將以下示例複製並貼上到 JDBCExample.java 中,編譯並執行如下:
import java.sql.*; public class JDBCExample { static final String DB_URL = "jdbc:mysql:///TUTORIALSPOINT"; static final String USER = "guest"; static final String PASS = "guest123"; 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); conn.setAutoCommit(false); // Create SQL statement String SQL = "INSERT INTO Employees(id,first,last,age) " + "VALUES(?, ?, ?, ?)"; // Create preparedStatement System.out.println("Creating statement..."); stmt = conn.prepareStatement(SQL); // print all the records ResultSet rs = stmt.executeQuery("Select * from Employees"); printResultSet(rs); // Set the variables stmt.setInt( 1, 400 ); stmt.setString( 2, "Pappu" ); stmt.setString( 3, "Singh" ); stmt.setInt( 4, 33 ); // Add it to the batch stmt.addBatch(); // Set the variables stmt.setInt( 1, 401 ); stmt.setString( 2, "Pawan" ); stmt.setString( 3, "Singh" ); stmt.setInt( 4, 31 ); // Add it to the batch stmt.addBatch(); // Create an int[] to hold returned values int[] count = stmt.executeBatch(); System.out.print("Batch Executed."); //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 JDBCExample.java C:\>
執行 **JDBCExample** 時,會產生以下結果:
C:\>java JDBCExample Creating statement... ID: 95, Age: 20, First: Sima, Last: Chug ID: 100, Age: 35, First: Zara, Last: Ali ID: 101, Age: 25, First: Mahnaz, Last: Fatma ID: 102, Age: 30, First: Zaid, Last: Khan ID: 103, Age: 30, First: Sumit, Last: Mittal ID: 110, Age: 20, First: Sima, Last: Chug ID: 200, Age: 30, First: Zia, Last: Ali ID: 201, Age: 35, First: Raj, Last: Kumar Batch Executed. ID: 95, Age: 20, First: Sima, Last: Chug ID: 100, Age: 35, First: Zara, Last: Ali ID: 101, Age: 25, First: Mahnaz, Last: Fatma ID: 102, Age: 30, First: Zaid, Last: Khan ID: 103, Age: 30, First: Sumit, Last: Mittal ID: 110, Age: 20, First: Sima, Last: Chug ID: 200, Age: 30, First: Zia, Last: Ali ID: 201, Age: 35, First: Raj, Last: Kumar ID: 400, Age: 33, First: Pappu, Last: Singh ID: 401, Age: 31, First: Pawan, Last: Singh C:\>
JDBC 示例中將 PreparedStatement(UPDATE)以自動提交為 False 的方式批次執行
在這個例子中,我們有三個靜態字串,包含資料庫連線 URL、使用者名稱和密碼。我們定義了一個 `printResultSet()` 方法,它以結果集作為引數,迭代並列印結果集的所有記錄。一旦所有更改提交後,`printResultSet()` 方法被呼叫以列印所有記錄。
現在使用 `DriverManager.getConnection()` 方法,我們準備了一個數據庫連線。使用 `setAutoCommit(false)`,我們將自動提交設定為 false,預設為 true。連線準備就緒後,我們使用 `connection.createPreparedStatement()` 方法建立了一個 PreparedStatement 物件,同時傳遞了一個帶有佔位符的 UPDATE 查詢。然後使用 `statement.executeQuery()`,所有記錄都被提取並使用 `printResultSet()` 方法列印。
現在我們已經為 preparedStatement 設定了值,然後使用 `addBatch()` 方法將 preparedStatement 新增到批處理中。新增後,我們再次為 preparedStatement 物件設定值,並使用 `addBatch()` 方法將 preparedStatement 新增到批處理中。然後使用 `executeBatch()` 方法,我們一次性執行所有語句,並使用 `commit()` 方法提交更改。現在使用 `printResultSet()`,我們正在列印 Employees 表中可用的所有記錄。
將以下示例複製並貼上到 JDBCExample.java 中,編譯並執行如下:
import java.sql.*; public class JDBCExample { static final String DB_URL = "jdbc:mysql:///TUTORIALSPOINT"; static final String USER = "guest"; static final String PASS = "guest123"; 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); conn.setAutoCommit(false); // Create SQL statement String SQL = "update employees set age=50 where id=?"; // Create preparedStatement System.out.println("Creating statement..."); stmt = conn.prepareStatement(SQL); // print all the records ResultSet rs = stmt.executeQuery("Select * from Employees"); printResultSet(rs); stmt.setInt(1, 35); stmt.addBatch(); stmt.setInt(1, 36); stmt.addBatch(); stmt.setInt(1, 37); stmt.addBatch(); // Create an int[] to hold returned values int[] count = stmt.executeBatch(); System.out.print("Batch Executed."); //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 JDBCExample.java C:\>
執行 **JDBCExample** 時,會產生以下結果:
C:\>java JDBCExample Creating statement... ID: 1, Age: 18, First: Zara, Last: Ali ID: 2, Age: 25, First: Mahnaz, Last: Fatma ID: 3, Age: 30, First: Zaid, Last: Khan ID: 4, Age: 28, First: Sumit, Last: Mittal ID: 7, Age: 20, First: Rita, Last: Tez ID: 8, Age: 20, First: Sita, Last: Singh ID: 21, Age: 35, First: Jeevan, Last: Rao ID: 22, Age: 40, First: Aditya, Last: Chaube ID: 25, Age: 35, First: Jeevan, Last: Rao ID: 26, Age: 35, First: Aditya, Last: Chaube ID: 34, Age: 45, First: Ahmed, Last: Ali ID: 35, Age: 31, First: Raksha, Last: Agarwal ID: 36, Age: 35, First: Sankalp, Last: Hawladar ID: 37, Age: 48, First: Anand, Last: Roy Batch Executed. ID: 1, Age: 18, First: Zara, Last: Ali ID: 2, Age: 25, First: Mahnaz, Last: Fatma ID: 3, Age: 30, First: Zaid, Last: Khan ID: 4, Age: 28, First: Sumit, Last: Mittal ID: 7, Age: 20, First: Rita, Last: Tez ID: 8, Age: 20, First: Sita, Last: Singh ID: 21, Age: 35, First: Jeevan, Last: Rao ID: 22, Age: 40, First: Aditya, Last: Chaube ID: 25, Age: 35, First: Jeevan, Last: Rao ID: 26, Age: 35, First: Aditya, Last: Chaube ID: 34, Age: 45, First: Ahmed, Last: Ali ID: 35, Age: 50, First: Raksha, Last: Agarwal ID: 36, Age: 50, First: Sankalp, Last: Hawladar ID: 37, Age: 50, First: Anand, Last: Roy C:\>