JDBC - Beispiel, Beispielcode

Dieses Kapitel enthält ein Beispiel zum Erstellen einer einfachen JDBC-Anwendung. Hier erfahren Sie, wie Sie eine Datenbankverbindung öffnen, eine SQL-Abfrage ausführen und die Ergebnisse anzeigen.

Alle in diesem Vorlagenbeispiel genannten Schritte werden in den folgenden Kapiteln dieses Lernprogramms erläutert.

JDBC-Anwendung erstellen

Die Erstellung einer JDBC-Anwendung umfasst die folgenden sechs Schritte:

  • Import the packages:Erfordert, dass Sie die Pakete einschließen, die die für die Datenbankprogrammierung erforderlichen JDBC-Klassen enthalten. Am häufigsten reicht die Verwendung von import java.sql. * Aus .

  • Register the JDBC driver: Erfordert, dass Sie einen Treiber initialisieren, damit Sie einen Kommunikationskanal mit der Datenbank öffnen können.

  • Open a connection:Erfordert die Verwendung der DriverManager.getConnection () -Methode, um ein Verbindungsobjekt zu erstellen, das eine physische Verbindung mit der Datenbank darstellt.

  • Execute a query: Erfordert die Verwendung eines Objekts vom Typ "Anweisung" zum Erstellen und Senden einer SQL-Anweisung an die Datenbank.

  • Extract data from result set:Erfordert, dass Sie die entsprechende ResultSet.getXXX () -Methode verwenden, um die Daten aus der Ergebnismenge abzurufen.

  • Clean up the environment: Erfordert das explizite Schließen aller Datenbankressourcen im Vergleich zum Verlassen auf die Garbage Collection der JVM.

Beispielcode

Dieses Beispielbeispiel kann als template wenn Sie in Zukunft Ihre eigene JDBC-Anwendung erstellen müssen.

Dieser Beispielcode wurde basierend auf der im vorherigen Kapitel vorgenommenen Umgebung und Datenbankeinrichtung geschrieben.

Kopieren Sie das folgende Beispiel und fügen Sie es in FirstExample.java ein. Kompilieren Sie es und führen Sie es wie folgt aus:

//STEP 1. Import required packages
import java.sql.*;

public class FirstExample {
   // 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{
      //STEP 2: Register JDBC driver
      Class.forName("com.mysql.jdbc.Driver");

      //STEP 3: Open a connection
      System.out.println("Connecting to database...");
      conn = DriverManager.getConnection(DB_URL,USER,PASS);

      //STEP 4: Execute a query
      System.out.println("Creating statement...");
      stmt = conn.createStatement();
      String sql;
      sql = "SELECT id, first, last, age FROM Employees";
      ResultSet rs = stmt.executeQuery(sql);

      //STEP 5: Extract data from result set
      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);
      }
      //STEP 6: Clean-up environment
      rs.close();
      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
}//end FirstExample

Lassen Sie uns nun das obige Beispiel wie folgt zusammenstellen:

C:\>javac FirstExample.java
C:\>

Wenn du rennst FirstExampleerzeugt es das folgende Ergebnis -

C:\>java FirstExample
Connecting to database...
Creating statement...
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: 28, First: Sumit, Last: Mittal
C:\>