JDBC - Sürücü Türleri
JDBC Sürücüsü nedir?
JDBC sürücüleri, veritabanı sunucunuzla etkileşim kurmak için JDBC API'de tanımlı arayüzleri uygular.
Örneğin, JDBC sürücülerini kullanmak, veritabanı bağlantılarını açmanıza ve SQL veya veritabanı komutları gönderdikten sonra Java ile sonuçları alarak onunla etkileşim kurmanıza olanak tanır.
JDK ile birlikte gelen Java.sql paketi, tanımlanmış davranışlarıyla çeşitli sınıflar içerir ve gerçek uygulamaları üçüncü taraf sürücülerle yapılır. Üçüncü taraf satıcılar , veritabanı sürücülerinde java.sql.Driver arayüzünü uygular .
JDBC Sürücü Türleri
JDBC sürücü uygulamaları, Java'nın çalıştığı çok çeşitli işletim sistemleri ve donanım platformları nedeniyle farklılık gösterir. Sun, uygulama türlerini aşağıda açıklanan Tip 1, 2, 3 ve 4 olmak üzere dört kategoriye ayırmıştır -
Tip 1: JDBC-ODBC Köprü Sürücüsü
Tip 1 sürücüde, her bir istemci makinesinde yüklü ODBC sürücülerine erişmek için bir JDBC köprüsü kullanılır. ODBC kullanmak, sisteminizde hedef veritabanını temsil eden bir Veri Kaynağı Adı (DSN) yapılandırmanızı gerektirir.
Java ilk çıktığında, bu yararlı bir sürücüdü çünkü çoğu veritabanı yalnızca ODBC erişimini destekliyordu, ancak şimdi bu tür bir sürücü yalnızca deneysel kullanım için veya başka bir alternatif mevcut olmadığında önerilir.
JDK 1.2 ile birlikte gelen JDBC-ODBC Köprüsü, bu tür bir sürücüye iyi bir örnektir.
Tür 2: JDBC-Yerel API
Tip 2 sürücüde, JDBC API çağrıları, veritabanına özgü yerel C / C ++ API çağrılarına dönüştürülür. Bu sürücüler tipik olarak veritabanı satıcıları tarafından sağlanır ve JDBC-ODBC Bridge ile aynı şekilde kullanılır. Satıcıya özgü sürücü, her bir istemci makineye yüklenmelidir.
Veritabanını değiştirirsek, yerel API'yi değiştirmemiz gerekir, çünkü bunlar bir veritabanına özgüdür ve şu anda çoğu zaman geçerliliğini yitirmişlerdir, ancak bir Tip 2 sürücü ile bir miktar hız artışı fark edebilirsiniz, çünkü bu ODBC'nin ek yükünü ortadan kaldırır.
Oracle Call Interface (OCI) sürücüsü, Tip 2 sürücüsünün bir örneğidir.
Tip 3: JDBC-Net saf Java
Tip 3 sürücüde, veritabanlarına erişmek için üç katmanlı bir yaklaşım kullanılır. JDBC istemcileri, bir ara yazılım uygulama sunucusuyla iletişim kurmak için standart ağ soketlerini kullanır. Soket bilgisi daha sonra ara yazılım uygulama sunucusu tarafından DBMS'nin gerektirdiği çağrı formatına çevrilir ve veritabanı sunucusuna iletilir.
Bu tür bir sürücü, istemcide hiçbir kodun kurulmasını gerektirmediğinden ve tek bir sürücü aslında birden çok veritabanına erişim sağlayabildiğinden son derece esnektir.
Uygulama sunucusunu bir JDBC "proxy'si" olarak düşünebilirsiniz, yani istemci uygulaması için çağrılar yapar. Sonuç olarak, bu sürücü türünü etkin bir şekilde kullanmak için uygulama sunucusunun yapılandırması hakkında biraz bilgiye ihtiyacınız vardır.
Uygulama sunucunuz veritabanıyla iletişim kurmak için Tip 1, 2 veya 4 sürücü kullanabilir, nüansları anlamak faydalı olacaktır.
Tip 4:% 100 Saf Java
Tip 4 sürücüde, saf Java tabanlı bir sürücü, soket bağlantısı aracılığıyla satıcının veritabanıyla doğrudan iletişim kurar. Bu, veritabanı için mevcut olan en yüksek performanslı sürücüdür ve genellikle satıcının kendisi tarafından sağlanır.
Bu tür bir sürücü son derece esnektir, istemci veya sunucuya özel bir yazılım yüklemenize gerek yoktur. Ayrıca bu sürücüler dinamik olarak indirilebilir.
MySQL'in Connector / J sürücüsü bir Tip 4 sürücüsüdür. Ağ protokollerinin tescilli doğası nedeniyle, veritabanı satıcıları genellikle tip 4 sürücüleri sağlar.
Hangi Sürücü Kullanılmalıdır?
Oracle, Sybase veya IBM gibi bir tür veritabanına erişiyorsanız, tercih edilen sürücü türü 4'tür.
Java uygulamanız aynı anda birden çok veri tabanına erişiyorsa, tip 3 tercih edilen sürücüdür.
Tip 2 sürücüler, veri tabanınız için henüz tip 3 veya tip 4 sürücünün bulunmadığı durumlarda kullanışlıdır.
Tip 1 sürücü, dağıtım düzeyinde bir sürücü olarak kabul edilmez ve genellikle yalnızca geliştirme ve test amacıyla kullanılır.