JDBC - Hızlı Kılavuz

JDBC nedir?

JDBC, Java Database CJava programlama dili ile çok çeşitli veritabanları arasında veritabanından bağımsız bağlantı için standart bir Java API'si olan onnectivity.

JDBC kitaplığı, yaygın olarak veritabanı kullanımıyla ilişkilendirilen görevlerin her biri için API'ler içerir:

  • Veritabanına bağlantı kurma

  • SQL veya MySQL ifadeleri oluşturma

  • Veritabanındaki SQL veya MySQL sorgularını yürütmek

  • Ortaya çıkan kayıtları görüntüleme ve değiştirme

Ön Koşul:

JDBC'yi öğrenmek için aşağıdaki iki konuyu iyi anlamanız gerekir:

  • Core JAVA Programlama

  • SQL veya MySQL Veritabanı

JDBC - Ortam Kurulumu:

Aşağıdaki kurulumu yaptığınızdan emin olun:

  • Çekirdek JAVA Kurulumu

  • SQL veya MySQL Veritabanı Kurulumu

Yukarıdakilerin dışında, projeniz için kullanacağınız bir veritabanı kurmanız gerekir. Bunun EMP olduğunu ve aynı veritabanında Çalışanlar tablosunda oluşturduğunuzu varsayarsak.

JDBC Uygulaması Oluşturma:

Bu eğiticide özetleyeceğim bir JDBC uygulaması oluşturmanın altı adımı vardır:

Paketleri içe aktarın:

Bu, veritabanı programlaması için gereken JDBC sınıflarını içeren paketleri eklemenizi gerektirir. Çoğu zaman, import java.sql. * Kullanmak aşağıdaki gibi yeterli olacaktır:

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

JDBC sürücüsünü kaydedin:

Bu, bir sürücüyü başlatmanızı gerektirir, böylece veritabanıyla bir iletişim kanalı açabilirsiniz. Bunu başarmak için kod parçacığı aşağıdadır:

//STEP 2: Register JDBC driver
Class.forName("com.mysql.jdbc.Driver");

Bir bağlantı açın:

Bu, aşağıdaki gibi veritabanıyla fiziksel bir bağlantıyı temsil eden bir Connection nesnesi oluşturmak için DriverManager.getConnection () yönteminin kullanılmasını gerektirir:

//STEP 3: Open a connection
//  Database credentials
static final String USER = "username";
static final String PASS = "password";
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);

Bir sorgu yürütün:

Bu, aşağıdaki gibi bir SQL ifadesi oluşturmak ve veritabanına göndermek için Statement veya PreparedStatement türünde bir nesnenin kullanılmasını gerektirir:

//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);

Bir SQL UPDATE, INSERT veya DELETE ifadesi gerekiyorsa, aşağıdaki kod parçacığı gerekli olacaktır:

//STEP 4: Execute a query
System.out.println("Creating statement...");
stmt = conn.createStatement();
String sql;
sql = "DELETE FROM Employees";
ResultSet rs = stmt.executeUpdate(sql);

Sonuç kümesinden verileri ayıklayın:

Veritabanından veri alıyorsanız bu adım gereklidir. Verileri sonuç kümesinden aşağıdaki şekilde almak için uygun ResultSet.getXXX () yöntemini kullanabilirsiniz:

//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);
}

Ortamı temizleyin:

Aşağıdaki gibi JVM'nin çöp koleksiyonuna güvenmek yerine tüm veritabanı kaynaklarını açıkça kapatmalısınız:

//STEP 6: Clean-up environment
rs.close();
stmt.close();
conn.close();

İlk JDBC Programı:

Yukarıdaki adımlara dayanarak, JDBC kodumuzu yazarken şablon olarak kullanabileceğimiz aşağıdaki birleştirilmiş örnek koda sahip olabiliriz:

Bu örnek kod, Ortam bölümünde yapılan ortam ve veritabanı kurulumuna göre yazılmıştır.

//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

Şimdi yukarıdaki örneği şu şekilde derleyelim:

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

Koştuğun zaman FirstExample, aşağıdaki sonucu verir:

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:\>

SQLException Yöntemleri:

Hem sürücüde hem de veritabanında bir SQLException oluşabilir. Böyle bir istisna oluştuğunda, SQLException türünde bir nesne catch yan tümcesine geçirilecektir.

İletilen SQLException nesnesi, istisna hakkında ek bilgi almak için aşağıdaki yöntemlere sahiptir:

Yöntem Açıklama
getErrorCode () Özel durumla ilişkili hata numarasını alır.
getMessage () Sürücü tarafından işlenen bir hata için JDBC sürücüsünün hata mesajını veya bir veritabanı hatası için Oracle hata numarasını ve mesajını alır.
getSQLState () XOPEN SQLstate dizesini alır. JDBC sürücü hatası için, bu yöntemden yararlı bilgiler döndürülmez. Veritabanı hatası için beş basamaklı XOPEN SQLstate kodu döndürülür. Bu yöntem null döndürebilir.
getNextException () İstisna zincirindeki bir sonraki Exception nesnesini alır.
Yığın İzi yazdır( ) Geçerli istisnayı veya atılabilirliği ve geri izini standart bir hata akışına yazdırır.
printStackTrace (PrintStream ler) Bu atılabilirliği ve geri izini belirttiğiniz yazdırma akışına yazdırır.
printStackTrace (PrintWriter w) Bu atılabilirliği ve geri izini belirttiğiniz yazıcı yazıcıya yazdırır.

Exception nesnesindeki bilgileri kullanarak, bir istisnayı yakalayabilir ve programınıza uygun şekilde devam edebilirsiniz. İşte bir try bloğunun genel biçimi:

try {
   // Your risky code goes between these curly braces!!!
}
catch(Exception ex) {
   // Your exception handling code goes between these 
   // curly braces, similar to the exception clause 
   // in a PL/SQL block.
}
finally {
   // Your must-always-be-executed code goes between these 
   // curly braces. Like closing database connection.
}

JDBC - Veri Türleri:

Aşağıdaki tablo, PreparedStatement veya CallableStatement nesnesinin setXXX () yöntemini veya ResultSet.updateXXX () yöntemini çağırdığınızda Java veri türünün dönüştürüldüğü varsayılan JDBC veri türünü özetler.

SQL JDBC / Java setXXX updateXXX
VARCHAR java.lang.String setString updateString
CHAR java.lang.String setString updateString
LONGVARCHAR java.lang.String setString updateString
BİT Boole setBoolean updateBoolean
SAYISAL java.math.BigDecimal setBigDecimal updateBigDecimal
TINYINT bayt setByte updateByte
SMALLINT kısa setShort updateShort
TAM int setInt updateInt
BÜYÜK uzun setLong updateLong
GERÇEK yüzer setFloat updateFloat
YÜZER yüzer setFloat updateFloat
ÇİFT çift setDouble updateDouble
DEĞİŞKEN bayt [] setBytes updateBytes
İKİLİ bayt [] setBytes updateBytes
TARİH java.sql.Date tarih ayarla Güncelleme Tarihi
ZAMAN java.sql.Time ayarlanan zaman Güncelleme zamanı
TIMESTAMP java.sql.Timestamp setTimestamp updateTimestamp
CLOB java.sql.Clob setClob updateClob
BLOB java.sql.Blob setBlob updateBlob
DİZİ java.sql.Array setARRAY updateARRAY
REF java.sql.Ref SetRef updateRef
YAPISI java.sql.Struct SetStruct updateStruct

JDBC 3.0, BLOB, CLOB, ARRAY ve REF veri türleri için gelişmiş desteğe sahiptir. ResultSet nesnesi, sunucu üzerindeki ilgili verileri doğrudan değiştirmenize olanak tanıyan updateBLOB (), updateCLOB (), updateArray () ve updateRef () yöntemlerine sahiptir.

SetXXX () ve updateXXX () yöntemleri, belirli Java türlerini belirli JDBC veri türlerine dönüştürmenizi sağlar. SetObject () ve updateObject () yöntemleri, hemen hemen her Java türünü JDBC veri türüyle eşlemenize olanak tanır.

ResultSet nesnesi, sütun değerini almak için her veri türü için karşılık gelen getXXX () yöntemini sağlar. Her yöntem sütun adıyla veya sıralı konumuna göre kullanılabilir.

SQL JDBC / Java setXXX getXXX
VARCHAR java.lang.String setString getString
CHAR java.lang.String setString getString
LONGVARCHAR java.lang.String setString getString
BİT Boole setBoolean getBoolean
SAYISAL java.math.BigDecimal setBigDecimal getBigDecimal
TINYINT bayt setByte getByte
SMALLINT kısa setShort getShort
TAM int setInt getInt
BÜYÜK uzun setLong getLong
GERÇEK yüzer setFloat getFloat
YÜZER yüzer setFloat getFloat
ÇİFT çift setDouble getDouble
DEĞİŞKEN bayt [] setBytes getBytes
İKİLİ bayt [] setBytes getBytes
TARİH java.sql.Date tarih ayarla getDate
ZAMAN java.sql.Time ayarlanan zaman getTime
TIMESTAMP java.sql.Timestamp setTimestamp getTimestamp
CLOB java.sql.Clob setClob getClob
BLOB java.sql.Blob setBlob getBlob
DİZİ java.sql.Array setARRAY getARRAY
REF java.sql.Ref SetRef getRef
YAPISI java.sql.Struct SetStruct getStruct

JDBC - Toplu İşleme:

Toplu İşleme, ilgili SQL ifadelerini bir toplu iş olarak gruplamanıza ve bunları veritabanına tek bir çağrı ile göndermenize olanak tanır.

Veritabanına aynı anda birkaç SQL ifadesi gönderdiğinizde, iletişim ek yükünü azaltır ve böylece performansı artırırsınız.

  • Bu özelliği desteklemek için JDBC sürücüleri gerekli değildir. Hedef veritabanının toplu güncelleme işlemeyi destekleyip desteklemediğini belirlemek için DatabaseMetaData.supportsBatchUpdates () yöntemini kullanmalısınız. JDBC sürücünüz bu özelliği destekliyorsa, yöntem true değerini döndürür.

  • addBatch()İfade, PreparedStatement ve CallableStatement yöntemi , toplu işleme bireysel ifadeler eklemek için kullanılır. executeBatch() birlikte gruplanmış tüm ifadelerin yürütülmesini başlatmak için kullanılır.

  • executeBatch() bir tamsayı dizisi döndürür ve dizinin her bir öğesi, ilgili güncelleme deyimi için güncelleme sayısını temsil eder.

  • İşleme için bir gruba ifade ekleyebildiğiniz gibi, bunları clearBatch()yöntem. Bu yöntem, addBatch () yöntemiyle eklediğiniz tüm ifadeleri kaldırır. Ancak, hangi ifadenin kaldırılacağını seçerek seçemezsiniz.

JDBC - Veri Akışı:

PreparedStatement nesnesi, parametre verilerini sağlamak için girdi ve çıktı akışlarını kullanma yeteneğine sahiptir. Bu, tüm dosyaları CLOB ve BLOB veri türleri gibi büyük değerleri tutabilen veritabanı sütunlarına yerleştirmenize olanak tanır.

Veri akışı sağlamak için kullanılabilecek aşağıdaki yöntemler vardır:

  • setAsciiStream(): Bu yöntem, büyük ASCII değerleri sağlamak için kullanılır.

  • setCharacterStream(): Bu yöntem, büyük UNICODE değerleri sağlamak için kullanılır.

  • setBinaryStream(): Bu yöntem, büyük ikili değerler sağlamak için kullanılır.

SetXXXStream () yöntemi, parametre yer tutucusunun yanı sıra dosya boyutu için fazladan bir parametre gerektirir. Bu parametre, sürücüye akış kullanılarak veritabanına ne kadar veri gönderilmesi gerektiğini bildirir.

Tüm bu konsept hakkında bir ayrıntı için, tam eğiticiden geçmeniz gerekir.