Перейти до вмісту

Java Database Connectivity

Матеріал з Вікіпедії — вільної енциклопедії.

Java DataBase Connectivity (англ. Java DataBase Connectivity — з'єднання з базами даних на Java), скорочено JDBC) — прикладний програмний інтерфейс Java, який визначає методи, з допомогою яких програмне забезпечення на Java здійснює доступ до бази даних. JDBC — це платформо-незалежний промисловий стандарт взаємодії Java-застосунків з різноманітними СУБД, реалізований у вигляді пакета java.sql, що входить до складу Java SE.

В основі JDBC лежить концепція так званих драйверів, що дозволяють отримувати з'єднання з базою даних по спеціально описаному URL. Драйвери можуть завантажуватись динамічно (під час роботи програми). Завантажившись, драйвер сам реєструє себе й викликається автоматично, коли програма вимагає URL, що містить протокол, за який драйвер «відповідає».

Інтерфейси

[ред. | ред. код]

JDBC API містить два основні типи інтерфейсів: перший — для розробників застосунків і другий (нижчого рівня) — для розробників драйверів.

З'єднання з базою даних описується класом, що реалізує інтерфейс java.sql.Connection.

Маючи з'єднання з базою даних, можна створювати об'єкти типу Statement, використовувані для здійснення запитів до бази даних на мові SQL.

Існують такі види типів Statement, що відрізняються своїм призначенням:

  • java.sql.Statement — Statement загального призначення;
  • java.sql.PreparedStatement — Statement, що служить для здійснення запитів, котрі містять підставні параметри (позначаються символом '?' у тілі запиту);
  • java.sql.CallableStatement — Statement, призначений для виклику збережених процедур.

Класjava.sql.ResultSet дозволяє легко обробляти результати запитів.

Переваги

[ред. | ред. код]

Перевагами JDBC вважаються:

  • Легкість розробки: розробник може не знати специфіки бази даних, з якою працює;
  • Код не змінюється, якщо компанія переходить на іншу базу даних;
  • Не треба встановлювати громіздку клієнтську програму;
  • До будь-якої бази можна під'єднатись через легко описуваний URL.

Приклади

[ред. | ред. код]

Приклад коду

JDBC для MySQL
Цей приклад використовує вільний драйвер JDBC для MySQL, який легко встановлюється в більшості дистрибутивів Linux через стандартні репозиторії.
package javaapplication1;
import java.sql.*;

public class Main {

    public static void main(String[] args) throws SQLException
    {
        /**
        * цей рядок вказує драйвер DB.
        * розкоментуйте, якщо прописуєте драйвер вручну
        */

        //Class.forName("com.mysql.jdbc.Driver").newInstance();

        Connection conn = DriverManager.getConnection(
            "jdbc:mysql://localhost:3306/db_name",
            "user", "password");
        
        if (conn==null)
        {
            System.out.println("Немає з'єднання з БД!");
            System.exit(0);
        }
        
        Statement stmt = conn.createStatement();
        ResultSet rs = stmt.executeQuery("SELECT * FROM users");

        while(rs.next())
        {
            System.out.println(rs.getRow() + ". " + rs.getString("firstname") + "\t" + rs.getString("lastname"));
        }
        
        // if(rs!=null)rs.close();
        
        /**
         * stmt.close();
         * При закритті Statement автоматично закриваються
         * всі пов'язані з ним відкриті об'єкти ResultSet
         */
        
        // if(stmt!=null)stmt.close();
        stmt.close();
    }
}

Див. також

[ред. | ред. код]

Посилання

[ред. | ред. код]