자바/스프링
스프링 데이터베이스 연결(JDBC,JPA)
tioon
2023. 7. 2. 22:40
JDBC(Java Database Connectivity)
-자바와 데이터베이스 간의 연결을 하는 자바 API입니다. 이를 이용해 자바에서 데이터베이스에 대한 쿼리를 수행하고 데이터를 검색,삽입,갱신,삭제등을 할 수 있습니다.
즉, 데이터베이스를 직접 사용하는게 아닌 자바를 활용해 데이터베이스에 접속하고, 해당 데이터베이스에서 쿼리를 실행해 결과를 받아오는 기술입니다.
JDBC 과정
- 데이터베이스 드라이버 로드
-자바에서 사용할 데이터베이스에 해당하는 JDBC 드라이버를 클래스 패스에 추가하고, 드라이버를 로드하는과정입니다. - 데이터베이스 연결 설정
-JDBC URL, 사용자명, 비밀번호 등을 설정하여 데이터베이스에 연결합니다. - Statement 생성
-SQL문을 실행하기 위해 Statement 객체 또는 PreparedStatement 객체를 생성합니다. - SQL 문 실행
-생성한 Statement 또는 PreparedStatement 객체를 사용하여 SQL 문을 실행하고 결과를 받아옵니다. - 결과처리
-SQL 실행 결과를 받아와서 원하는 방식으로 처리하는 과정입니다. 데이터를 읽거나 쓰는 등의 작업을 수행할 수 있습니다. - 연결 종료
-모든 작업이 완료되면 데이터베이스 연결을 종료합니다.
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();
}
}
}