- 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 - 使用 Statement 物件進行批次處理
以下是使用 Statement 物件進行批次處理的典型步驟序列:
使用 createStatement() 方法建立一個 Statement 物件。
使用 setAutoCommit() 將自動提交設定為 false。
使用在建立的 Statement 物件上使用 addBatch() 方法將任意數量的 SQL 語句新增到批處理中。
使用在建立的 Statement 物件上使用 executeBatch() 方法執行所有 SQL 語句。
最後,使用 commit() 方法提交所有更改。
此示例程式碼基於前面章節中完成的環境和資料庫設定編寫。
JDBC 示例中使用 AutoCommit 為 False 的批次執行 SQL 語句
在此示例中,我們有三個靜態字串包含資料庫連線 URL、使用者名稱和密碼。我們定義了一個 printResultSet() 方法,它以結果集作為引數,迭代它並列印結果集的所有記錄。一旦所有更改提交,就會呼叫 printResultSet() 方法列印所有記錄。
現在,使用 DriverManager.getConnection() 方法,我們準備了一個數據庫連線。使用 setAutoCommit(false),我們將自動提交設定為 false,預設情況下為 true。連線準備就緒後,我們使用 connection.createStatement() 方法建立了一個 Statement 物件。在建立 Statement 物件時,我們使用了 ResultSet 型別 TYPE_SCROLL_INSENSITIVE 和 CONCUR_UPDATABLE。然後使用 statement.executeQuery() 獲取所有記錄,並使用 printResultSet() 方法列印它們。
現在,我們準備了一個 SQL 插入語句作為字串,並使用 addBatch() 方法將其新增到 Statement 物件中。類似地,一個插入語句和一個更新語句使用 addBatch() 方法新增到 Statement 物件中。然後,使用 executeBatch() 方法,我們一次性執行所有語句,並使用 commit() 方法提交更改。現在,使用 printResultSet(),我們列印 Employees 表中所有可用的記錄。
複製並貼上以下示例到 JDBCExample.java 中,編譯並執行如下:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
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);
Statement stmt = conn.createStatement(
ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_UPDATABLE)
) {
conn.setAutoCommit(false);
ResultSet rs = stmt.executeQuery("Select * from Employees");
printResultSet(rs);
// Create SQL statement
String SQL = "INSERT INTO Employees (first, last, age) " +
"VALUES('Zia', 'Ali', 30)";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);
// Create one more SQL statement
SQL = "INSERT INTO Employees (first, last, age) " +
"VALUES('Raj', 'Kumar', 35)";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);
// Create one more SQL statement
SQL = "UPDATE Employees SET age = 35 " +
"WHERE id = 7";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);
// 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 JDBCExample.java C:\>
執行 JDBCExample 時,會產生以下結果:
C:\>java JDBCExample 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: 20, First: Sita, Last: Singh ID: 8, Age: 20, First: Rita, Last: Tez ID: 9, Age: 20, First: Sita, Last: Singh 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 C:\>
JDBC 示例中使用 AutoCommit 為 True 的批次執行 SQL 語句
在此示例中,我們有三個靜態字串包含資料庫連線 URL、使用者名稱和密碼。我們定義了一個 printResultSet() 方法,它以結果集作為引數,迭代它並列印結果集的所有記錄。一旦所有更改提交,就會呼叫 printResultSet() 方法列印所有記錄。
現在,使用 DriverManager.getConnection() 方法,我們準備了一個數據庫連線。連線準備就緒後,我們使用 connection.createStatement() 方法建立了一個 Statement 物件。在建立 Statement 物件時,我們使用了 ResultSet 型別 TYPE_SCROLL_INSENSITIVE 和 CONCUR_UPDATABLE。然後使用 statement.executeQuery() 獲取所有記錄,並使用 printResultSet() 方法列印它們。
現在,我們準備了一個 SQL 插入語句作為字串,並使用 addBatch() 方法將其新增到 Statement 物件中。類似地,一個插入語句和一個更新語句使用 addBatch() 方法新增到 Statement 物件中。然後,使用 executeBatch() 方法,我們一次性執行所有語句,並使用 commit() 方法提交更改。現在,使用 printResultSet(),我們列印 Employees 表中所有可用的記錄。
複製並貼上以下示例到 JDBCExample.java 中,編譯並執行如下:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
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);
Statement stmt = conn.createStatement(
ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_UPDATABLE)
) {
ResultSet rs = stmt.executeQuery("Select * from Employees");
System.out.println("Displaying records before batch processing.");
System.out.println("--------------------------------------------");
printResultSet(rs);
// Create SQL statement
String SQL = "INSERT INTO Employees (first, last, age) " +
"VALUES('Ahmed', 'Ali', 45)";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);
// Create one more SQL statement
SQL = "INSERT INTO Employees (first, last, age) " +
"VALUES('Raksha', 'Agarwal', 31)";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);
// Create one more SQL statement
SQL = "UPDATE Employees SET age = 35 " +
"WHERE id = 26";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);
// Create an int[] to hold returned values
int[] count = stmt.executeBatch();
System.out.println("Successfully executed batch.");
rs = stmt.executeQuery("Select * from Employees");
printResultSet(rs);
System.out.println("-------------------------------------");
stmt.close();
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
輸出
現在,讓我們按如下方式編譯上述示例:
C:\>javac JDBCExample.java C:\>
執行 JDBCExample 時,會產生以下結果:
C:\>java JDBCExample Displaying records before batch processing. -------------------------------------------- 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 ---------------------------------------- Successfully executed batch. 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 ------------------------------------- C:\>