简介:

Java是一种面向对象,安全灵活的编程语言,已经成为了世界上最流行的编程语言之一。Java语言的一个重要应用领域就是数据库开发。通过Java JDBC(Java Database Connectivity) API,开发人员可以使用Java语言来访问并操作各种数据库。

本篇资料将会详细介绍Java JDBC数据库开发的相关知识,从入门到精通,涵盖了JDBC的基本概念、如何连接数据库、如何执行SQL语句以及如何处理数据库事务等方面。此外,还会给出许多实际例子,来演示如何应用JDBC API来实现各种数据库操作。读者可以通过本篇资料来了解和掌握Java JDBC数据库开发的相关技能。

章节列表:

1. JDBC的基本概念

2. 连接不同类型的数据库

3. 执行SQL语句

4. 处理查询结果集

5. 处理事务

6. JDBC的高级特性

第一章:JDBC的基本概念

Java Database Connectivity(JDBC)是一种用于连接各种关系型数据库的API,它允许Java应用程序通过标准的Java编程语言方式访问数据库,包括连接数据库、执行SQL语句、处理查询结果等操作。

JDBC的三个核心组件:

1. Driver:用于连接数据库的驱动程序。

2. Connection:与数据库的连接对象。

3. Statement:执行SQL语句的对象。

第二章:连接不同类型的数据库

在JDBC中,不同的数据库需要使用特定数据库的驱动程序。常见的数据库有MySQL、Oracle、SQL Server等。

连接MySQL数据库示例:

import java.sql.*;
public class ConnectMySQL {
   static final String USER = "username";
   static final String PASS = "password";
   static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";

   public static void main(String[] args) {
      Connection conn = null;
      Statement stmt = null;
      try{
         Class.forName("com.mysql.jdbc.Driver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected database successfully...");
         stmt = conn.createStatement();
         String sql = "SELECT id, first, last, age FROM Employees";
         ResultSet rs = stmt.executeQuery(sql);
         while(rs.next()){
            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"));
         }
         rs.close();
      }catch(SQLException se){
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(stmt!=null)
               conn.close();
         }catch(SQLException se){
         }
         try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

连接Oracle数据库示例:

import java.sql.*;
public class ConnectOracle {
   static final String USER = "username";
   static final String PASS = "password";
   static final String DB_URL = "jdbc:oracle:thin:@localhost:1521:xe";

   public static void main(String[] args) {
      Connection conn = null;
      Statement stmt = null;
      try{
         Class.forName("oracle.jdbc.driver.OracleDriver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected database successfully...");
         stmt = conn.createStatement();
         String sql = "SELECT id, first, last, age FROM Employees";
         ResultSet rs = stmt.executeQuery(sql);
         while(rs.next()){
            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"));
         }
         rs.close();
      }catch(SQLException se){
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(stmt!=null)
               conn.close();
         }catch(SQLException se){
         }
         try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

第三章:执行SQL语句

在JDBC中,使用Statement和PreparedStatement对象分别执行静态SQL和动态SQL语句。

创建Statement对象执行静态SQL示例:
 

import java.sql.*;
public class ExecuteStatement {
   static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";
   static final String USER = "username";
   static final String PASS = "password";
   static final String INSERT_SQL = "INSERT INTO Employees (id, first, last, age) VALUES (100, 'John', 'Doe', 25)";

   public static void main(String[] args) {
      Connection conn = null;
      Statement stmt = null;
      try{
         Class.forName("com.mysql.jdbc.Driver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected database successfully...");
         stmt = conn.createStatement();
         System.out.println("Executing SQL query...");
         stmt.executeUpdate(INSERT_SQL);
         System.out.println("SQL query executed successfully...");
      }catch(SQLException se){
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(stmt!=null)
               conn.close();
         }catch(SQLException se){
         }
         try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

创建PreparedStatement对象执行动态SQL示例:

import java.sql.*;
public class ExecutePreparedStatement {
   static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";
   static final String USER = "username";
   static final String PASS = "password";
   static final String SQL = "INSERT INTO Employees (id, first, last, age) VALUES (?, ?, ?, ?)";

   public static void main(String[] args) {
      Connection conn = null;
      PreparedStatement pstmt = null;
      try{
         Class.forName("com.mysql.jdbc.Driver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected database successfully...");
         pstmt = conn.prepareStatement(SQL);
         pstmt.setInt(1, 101);
         pstmt.setString(2, "Tom");
         pstmt.setString(3, "Smith");
         pstmt.setInt(4, 30);
         System.out.println("Executing SQL query...");
         pstmt.executeUpdate();
         System.out.println("SQL query executed successfully...");
      }catch(SQLException se){
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(pstmt!=null)
               conn.close();
         }catch(SQLException se){
         }
         try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

第四章:处理查询结果集

在JDBC中,通过ResultSet对象来处理查询结果集,包括遍历查询结果、获取指定列的值等操作。

处理查询结果集示例:

import java.sql.*;
public class ProcessResultSet {
   static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";
   static final String USER = "username";
   static final String PASS = "password";
   static final String SQL = "SELECT id, first, last, age FROM Employees";

   public static void main(String[] args) {
      Connection conn = null;
      Statement stmt = null;
      try{
         Class.forName("com.mysql.jdbc.Driver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected database successfully...");
         stmt = conn.createStatement();
         ResultSet rs = stmt.executeQuery(SQL);
         while(rs.next()){
            int id  = rs.getInt("id");
            int age = rs.getInt("age");
            String first = rs.getString("first");
            String last = rs.getString("last");
            System.out.print("ID: " + id);
            System.out.print(", Age: " + age);
            System.out.print(", First: " + first);
            System.out.println(", Last: " + last);
         }
         rs.close();
      }catch(SQLException se){
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(stmt!=null)
               conn.close();
         }catch(SQLException se){
         }
         try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

第五章:处理事务

在JDBC中,事务处理对于保证数据的一致性非常重要。通过对Connection对象开启事务、设置保存点、提交或回滚,可以实现对数据库中数据的增删改操作的原子性和持久性。

处理事务示例:
 

import java.sql.*;
public class ProcessTransaction {
   static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";
   static final String USER = "username";
   static final String PASS = "password";

   public static void main(String[] args) {
      Connection conn = null;
      Statement stmt = null;
      try{
         Class.forName("com.mysql.jdbc.Driver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected datab ase successfully...");
         conn.setAutoCommit(false);
         stmt = conn.createStatement();
         String sql1 = "INSERT INTO Employees (id, first, last, age) VALUES (200, 'Jack', 'Jones', 25)";
         stmt.executeUpdate(sql1);
         String sql2 = "INSERT INTO Employees (id, first, last, age) VALUES (201, 'Mary', 'Smith', 32)";
         stmt.executeUpdate(sql2);
         Savepoint savepoint = conn.setSavepoint("Savepoint1");
         String sql3 = "INSERT INTO Employees (id, first, last, age) VALUES (202, 'Tom', 'Brown', 28)";
         stmt.executeUpdate(sql3);
         String sql4 = "INSERT INTO Employees (id, first, last, age) VALUES (203, 'Linda', 'White', 41)";
         stmt.executeUpdate(sql4);
         String sql5 = "INSERT INTO Employees (id, first, last, age) VALUES (204, 'Mike', 'Green', 38)";
         stmt.executeUpdate(sql5);
         conn.commit();
         System.out.println("Transaction committed successfully...");
      }catch(SQLException se){
         try{
            if(conn!=null)
               conn.rollback();
         }catch(SQLException se2){
            se2.printStackTrace();
         }
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(stmt!=null)
               conn.close();
         }catch(SQLException se){
         }
         try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

第六章:JDBC的高级特性

除了基本的JDBC操作,还有很多高级特性可以进一步优化数据库开发,包括批处理、元数据查询、数据库连接池等。

JDBC批处理示例:

 

import java.sql.*;
public class ExecuteBatch {
   static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";
   static final String USER = "username";
   static final String PASS = "password";

   public static void main(String[] args) {
      Connection conn = null;
      Statement stmt = null;
      try{
         Class.forName("com.mysql.jdbc.Driver");
         System.out.println("Connecting to database...");
         conn = DriverManager.getConnection(DB_URL,USER,PASS);
         System.out.println("Connected database successfully...");
         stmt = conn.createStatement();
         conn.setAutoCommit(false);
         stmt.addBatch("INSERT INTO Employees (id, first, last, age) VALUES (300, 'John', 'Doe', 25)");
         stmt.addBatch("INSERT INTO Employees (id, first, last, age) VALUES (301, 'Mary', 'Smith', 32)");
         stmt.addBatch("INSERT INTO Employees (id, first, last, age) VALUES (302, 'Tom', 'Brown', 28)");
         stmt.addBatch("INSERT INTO Employees (id, first, last, age) VALUES (303, 'Linda', 'White', 41)");
         stmt.addBatch("INSERT INTO Employees (id, first, last, age) VALUES (304, 'Mike', 'Green', 38)");
         int[] count = stmt.executeBatch();
         conn.commit();
         System.out.println("Batch executed successfully...");
         for(int i=0;i<count.length;i++){
            System.out.println(count[i] + " row(s) affected.");
         }
      }catch(SQLException se){
         try{
            if(conn!=null)
               conn.rollback();
         }catch(SQLException se2){
            se2.printStackTrace();
         }
         se.printStackTrace();
      }catch(Exception e){
         e.printStackTrace();
      }finally{
         try{
            if(stmt!=null)
               conn.close();
         }catch(SQLException se){
         }try{
            if(conn!=null)
               conn.close();
         }catch(SQLException se){
            se.printStackTrace();
         }
      }
      System.out.println("Goodbye!");
   }
}

JDBC元数据查询可以通过Connection对象的getMetaData方法来获取数据库的元数据信息,包括表结构、列信息、索引信息等。通过元数据查询,可以方便地了解数据库的基本信息,从而更好地进行数据库开发。

元数据查询示例:
 

import java.sql.*;
public class MetadataQuery {
static final String DB_URL = "jdbc:mysql://localhost:3306/Employee";
static final String USER = "username";
static final String PASS = "password";

public static void main(String[] args) {
Connection conn = null;
try{
Class.forName("com.mysql.jdbc.Driver");
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
System.out.println("Connected database successfully...");
DatabaseMetaData dbmd=conn.getMetaData();
System.out.println("Driver Name: "+dbmd.getDriverName());
System.out.println("Driver Version: "+dbmd.getDriverVersion());
System.out.println("Database Name: "+dbmd.getDatabaseProductName());
System.out.println("Database Version: "+dbmd.getDatabaseProductVersion());
System.out.println("Tables:");
ResultSet rs=dbmd.getTables(null,null,null,new String[]{"TABLE"});
while(rs.next()){
System.out.println(rs.getString("TABLE_NAME"));
}
conn.close();
}catch(SQLException se){
se.printStackTrace();
}catch(Exception e){
e.printStackTrace();
}finally{
try{
if(conn!=null)
conn.close();
}catch(SQLException se){
se.printStackTrace();
}
}
System.out.println("Goodbye!");
}
}

数据库连接池是一种重要的数据库优化方案,通过建立连接池,可以避免频繁地创建和销毁数据库连接,从而提高系统性能并减少数据库开销。JDBC连接池可以通过一些现成的开源项目进行实现,包括Apache Commons DBCP和C3P0等。

本篇资料到此结束,希望能够通过学习JDBC,掌握Java对关系型数据库的访问和操作,提高系统性能和稳定性。