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.