Could not open JPA EntityManager for transaction; nested exception is java.util.NoSuchElementException 위 트랜잭션을 만들 수 없다는 오류는 검색을 해보면 DB Connection Pool이 작거나, 접속 정보가 잘못되어 DB 연결에 실패하는 경우 발생할 수 있는데 최근에 이런 경우가 아닌 문제로 오류를 경험하게 되어 기록한다. DB 구성이 쓰기/읽기로 구분되어 있는 환경에서, JPA로 DB 작업을 하고 Annotation으로 쓰기/읽기 DB를 제어한다면 Annotation을 설정의 누락이나 실수로 읽기 DB에 쓰기 작업을 시도하여 같은 오류가 발생할 수 있다. 자신의 소스코드가 읽기 DB에 쓰기 작업을 하고 있지 않은지 확..
Spring Framework에서 JPA 사용 시 @Transactional(readOnly = true) 애노테이션을 사용하면 트랜잭션을 읽기 전용 모드로 동작시킬 수 있고, 성능 향상을 볼 수 있다. JPA는 기본적으로 엔터티를 영속성 컨텍스트에 관리하게 되고, 영속성 컨텍스트는 변경 감지를 위해 스냅샷 인스턴스를 보관하여 메모리를 사용하게 된다. 엔터티를 조회만 하는 경우 변경 감지와 메모리 사용은 불필요하므로 @Transactional(readOnly = true) 애노테이션을 사용하면 트랜잭션이 읽기 전용 모드로 설정되어 변경 감지할 엔터티를 줄이고 메모리 사용을 줄일 수 있다. @Transactional(readOnly = true) 애노테이션을 사용하면 Spring Data JPA는 Hibe..
JPA는 무엇인가? JPA는 Java Persistence API의 약자이며, JAVA 애플리케이션에서 관계형 데이터베이스를 어떻게 사용해야 되는지를 정의한 인터페이스이다. 라이브러리가 아니다. 인터페이스이므로 구현이 없다. 개발자가 직접 SQL을 작성하지 않아도 된다. 개발자 대신 적절한 SQL을 생성해서 DB에 전달하고, 객체에 자동으로 Mapping 해준다. 내부적으로 JDBC(Java Database Connectivity) API를 활용한다. SQL을 JPA가 자동으로 해결해 준다는 점에서 생성성을 높여준다. ORM은 무엇인가? ORM(Object-Relational Mapping)은 객체와 관계형 데이터베이스의 데이터를 자동으로 Mapping(연결)해주는 것을 말한다. 영속성이란 무엇인가? 데..
JPA는 기술 명세이며, 인터페이스이다. JPA는 Java Persistence API의 약자이며, JAVA 애플리케이션에서 관계형 데이터베이스를 어떻게 사용해야 되는지를 정의한 인터페이스이다. 라이브러리가 아니다. 인터페이스이므로 구현이 없다. JPA를 구현한 여러 라이브러리가 존재한다. Spring으로 개발하다 보면 Hibernate 자주 볼 수 있는데, Hibernate는 JPA를 구현한 라이브러리이다. Hibernate 외 DataNucleus, EclipseLink 등 다른 여러 라이브러리가 존재한다.(꼭 Hibernate를 사용해야되는 것은 아니다.) Spring Data JPA는 개발자가 쉽게 JPA를 사용할 수 있도록 한 Spring에서 제공하는 모듈이다. Spring으로 개발하다 보면 J..
JPA를 사용 시 보통 Entity 클래스에 포함된 모든 데이터를 읽어오게 되는데, 일부 컬럼만 가져오고 싶을 때가 있다. 일부 컬럼만 가져오는 방법을 정리한다. 아래 정의한 Entity 클래스에서 @Entity @Table(name = "deal") public class Deal { @Id @GeneratedValue private Long id; private String name; private Integer price; @OnoToOne(mappedBy = "deal", cascade = CascadeType.ALL) private DealExtra dealExtra; } 일부 컬럼만 가져오기 위한 Interface를 아래와 같이 정의한다. public interface DealMapping {..
- Total
- Today
- Yesterday
- springframework
- libavformat
- development
- ffmpeg
- Rolling-Restart
- jdk7
- JPA
- DATABASE
- springboot
- HTTP Live Streaming
- Virtual Thread
- CentOS
- AVIOContext
- JAXB
- C/C++
- JDK21
- elasticsearch
- Java
- HLS
- programmer
- Programming
- HDFS
- DB
- jdk6
- oid
- Spring
- fluentd
- onbeforeunload
- springjpa
- popupWindow
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |