JDBC-批处理和语句对象
JDBC-批处理和语句对象
以下是一些对语句对象使用批处理的典型步骤:
这个示例代码基于之前的环境和数据库设置。
复制粘贴以下代码,编译运行如下:
编译以上代码:
当你运行JDBCExample,产生如下输出:
以下是一些对语句对象使用批处理的典型步骤:
- 使用createStatment方法闯将语句对象
- 使用setAutoCommit()将auto-commit设置为false
- 使用addBatch()添加尽可能多的SQL语句到语句对象中
- 使用executeBatch()方法执行所有的SQL语句创建语句对象
- 最终,使用commit()方法上传所有的修改
这个示例代码基于之前的环境和数据库设置。
复制粘贴以下代码,编译运行如下:
- // Import required packages
- import java.sql.*;
- public class JDBCExample {
- // JDBC driver name and database URL
- static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
- static final String DB_URL = "jdbc:mysql://localhost/EMP";
- // Database credentials
- static final String USER = "username";
- static final String PASS = "password";
- public static void main(String[] args) {
- Connection conn = null;
- Statement stmt = null;
- try{
- // Register JDBC driver
- Class.forName("com.mysql.jdbc.Driver");
- // Open a connection
- System.out.println("Connecting to database...");
- conn = DriverManager.getConnection(DB_URL,USER,PASS);
- // Create statement
- System.out.println("Creating statement...");
- stmt = conn.createStatement();
- // Set auto-commit to false
- conn.setAutoCommit(false);
- // First, let us select all the records and display them.
- printRows( stmt );
- // Create SQL statement
- String SQL = "INSERT INTO Employees (id, first, last, age) " +
- "VALUES(200,'Zia', 'Ali', 30)";
- // Add above SQL statement in the batch.
- stmt.addBatch(SQL);
- // Create one more SQL statement
- SQL = "INSERT INTO Employees (id, first, last, age) " +
- "VALUES(201,'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 = 100";
- // 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();
- // Again, let us select all the records and display them.
- printRows( stmt );
- // Clean-up environment
- stmt.close();
- conn.close();
- }catch(SQLException se){
- //Handle errors for JDBC
- se.printStackTrace();
- }catch(Exception e){
- //Handle errors for Class.forName
- e.printStackTrace();
- }finally{
- //finally block used to close resources
- try{
- if(stmt!=null)
- stmt.close();
- }catch(SQLException se2){
- }// nothing we can do
- try{
- if(conn!=null)
- conn.close();
- }catch(SQLException se){
- se.printStackTrace();
- }//end finally try
- }//end try
- System.out.println("Goodbye!");
- }//end main
- public static void printRows(Statement stmt) throws SQLException{
- System.out.println("Displaying available rows...");
- // Let us select all the records and display them.
- String sql = "SELECT id, first, last, age FROM Employees";
- ResultSet rs = stmt.executeQuery(sql);
- while(rs.next()){
- //Retrieve by column name
- int id = rs.getInt("id");
- int age = rs.getInt("age");
- String first = rs.getString("first");
- String last = rs.getString("last");
- //Display values
- System.out.print("ID: " + id);
- System.out.print(", Age: " + age);
- System.out.print(", First: " + first);
- System.out.println(", Last: " + last);
- }
- System.out.println();
- rs.close();
- }//end printRows()
- }//end JDBCExample
编译以上代码:
- C:>javac JDBCExample.java
- C:>
当你运行JDBCExample,产生如下输出:
- C:>java JDBCExample
- Connecting to database...
- Creating statement...
- Displaying available rows...
- ID: 95, Age: 20, First: Sima, Last: Chug
- ID: 100, Age: 18, 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
- Displaying available rows...
- 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
- Goodbye!
- C:>