자바/스프링

스프링 데이터베이스 연결(JDBC,JPA)

tioon 2023. 7. 2. 22:40
JDBC(Java Database Connectivity)

-자바와 데이터베이스 간의 연결을 하는 자바 API입니다. 이를 이용해 자바에서 데이터베이스에 대한 쿼리를 수행하고 데이터를 검색,삽입,갱신,삭제등을 할 수 있습니다.
즉, 데이터베이스를 직접 사용하는게 아닌 자바를 활용해 데이터베이스에 접속하고, 해당 데이터베이스에서 쿼리를 실행해 결과를 받아오는 기술입니다.

 

 

 

JDBC 과정

  1. 데이터베이스 드라이버 로드
    -자바에서 사용할 데이터베이스에 해당하는 JDBC 드라이버를 클래스 패스에 추가하고, 드라이버를 로드하는과정입니다.

  2. 데이터베이스 연결 설정
    -JDBC URL, 사용자명, 비밀번호 등을 설정하여 데이터베이스에 연결합니다.

  3. Statement 생성
    -SQL문을 실행하기 위해 Statement 객체 또는 PreparedStatement 객체를 생성합니다.

  4. SQL 문 실행
    -생성한 Statement 또는 PreparedStatement 객체를 사용하여 SQL 문을 실행하고 결과를 받아옵니다.

  5. 결과처리
    -SQL 실행 결과를 받아와서 원하는 방식으로 처리하는 과정입니다. 데이터를 읽거나 쓰는 등의 작업을 수행할 수 있습니다.

  6. 연결 종료
    -모든 작업이 완료되면 데이터베이스 연결을 종료합니다.

 

 

JDBC 예시코드
public class JdbcExample {
    public static void main(String[] args) {
        // JDBC 드라이버 로드
        try {
            Class.forName("com.mysql.cj.jdbc.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }

        // 데이터베이스 연결 설정
        String url = "jdbc:mysql://localhost:3306/mydatabase"; // JDBC URL
        String username = "root";
        String password = "password";

        try (Connection connection = DriverManager.getConnection(url, username, password)) {
            // Statement 생성
            Statement statement = connection.createStatement();

            // SQL 문 실행
            String sql = "SELECT * FROM employees"; //SQL문
            ResultSet resultSet = statement.executeQuery(sql);

            // 결과 처리
            while (resultSet.next()) {
                int id = resultSet.getInt("id");
                String name = resultSet.getString("name");
                int age = resultSet.getInt("age");

                System.out.println("ID: " + id + ", Name: " + name + ", Age: " + age);
            }

            // 연결 해제
            resultSet.close();
            statement.close();
            connection.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

 

 

JDBC의 문제
  • 반복적인 코드
    -JDBC는 개발자가 직접 데이터베이스와의 연결, 트랜잭션 관리, 쿼리 실행 등의 반복적인 작업을 처리해야하므로, 코드중복과 가독성이 떨어지는 긴 코드가 발생할 수 있습니다.

  • 유지보수성 하락
    -JDBC는 특정 데이터베이스에 종속적이므로, 데이터베이스를 변경하거나,데이터베이스 여러개를 동시에 지원하기위해선 JDBC코드를 수정해야할 수 있어서 유지보수성이 하락할 수 있습니다.
  • 직접 매핑
    -JDBC는 SQL 기반으로 작동하기 때문에 개발자가 직접 SQL 쿼리를 작성하고, 데이터베이스와의 매핑 작업을 처리해야합니다. 이는 객체와 데이터베이스간의 매핑을 처리할때 개발자가 수동으로 처리하기 때문에 객체와 데이터베이스간의  불일치가 발생할 수 있습니다.

 

 

 

 

JPA(Java Persistence API)

- JAVA언어를 위한 ORM 기술입니다. ORM을 활용하여 데이터베이스의 데이터를 객체로 매핑하고, 객체를 데이터베이스에 데이터베이스에 저장하고 검색하기 위한 기능을 제공합니다. 이는 개발자가 직접 SQL쿼리를 작성하지 않아도 데이터 베이스와 상호작용할 수 있또록 하며, 객체지향 프로그래밍을 더 잘 지킬 수 있게 합니다.JPA는 내부적으로 JDBC가 구현되어있어 개발자가 따로 SQL문을 입력하지않아도, JPA가 자동으로 JDBC를 이용해 데이터베이스와 통신합니다.

 

 

ORM(Object-Relational Mapping)

-객체지향 프로그래밍과 관계형 데이터베이스 간의 데이터를 자동으로 매핑하는 기술입니다.객체와 관계형 데이터베이스 의 테이블과 매핑작업을 자동화하여 개발자가 SQL문을 직접 작성하지 않고도 데이터베이스와 상호작용할 수 있도록 도와주는 것입니다.
이는 개발 생산성을 향상시키고 객체지향적인 코드작성을 가능하게 하지만, 속도성능저하가 있을수 있습니다.

 

 

 

JDBC와 JPA의 차이
  JDBC JPA
개념 JAVA언어를 활용,데이터베이스 접속 및 쿼리 실행 API JAVA언어를 활용,ORM 인터페이스
수준 저수준  고수준
매핑 개발자가 직접 SQL 쿼리 작성 및 매핑 JPA가 자동 객체-관계 매핑
작업 반복성 개발자가 데이터베이스 연결, 쿼리작성등을 수동으로 함. 자동으로 데이터베이스 연결, 트랜잭션관리등을 함.
성능 빠름 비교적 느림

 

 

JPA예시코드
@Entity
@Table(name = "employees")
public class Employee {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    
    @Column(name = "name")
    private String name;
    
    @Column(name = "age")
    private int age;
    
    // getters and setters
}

public class JpaExample {
    public static void main(String[] args) {

        // 영속성 유닛 설정
        EntityManagerFactory emf = Persistence.createEntityManagerFactory("myPersistenceUnit");

        // 엔티티 매니저 생성
        EntityManager em = emf.createEntityManager();

        try {
            // 트랜잭션 시작
            em.getTransaction().begin();

            // 엔티티 저장
            Employee employee1 = new Employee();
            employee1.setName("John Doe");
            employee1.setAge(30);
            em.persist(employee1);

            Employee employee2 = new Employee();
            employee2.setName("Jane Smith");
            employee2.setAge(28);
            em.persist(employee2);

            // 트랜잭션 커밋
            em.getTransaction().commit();

       } catch (Exception e) {
            // 예외 처리
            e.printStackTrace();
            em.getTransaction().rollback();

        } finally {
            // 엔티티 매니저 종료
            em.close();

            // 엔티티 매니저 팩토리 종료
            emf.close();
        }
    }
}