RestTemplate으로 외부 연동 API 응답 값을 받을때 굉장히 다양한 case convention을 경험할 수 있다.하지만 restTemplate에 기본적으로 등록되어 있는 messageConverters에서는 필드 매핑시 snake_case를 제대로 매핑하지 못해서 null이 들어가는 경우가 있다.restTemplate에 Spring이 이미 등록한 기본 MappingJackson2HttpMessageConverter보다 우선하도록 새롭게 커스텀한 messageConverter를 등록하자.jackson version 2.7 이전에서는 PropertyNamingStrategy. CAMEL_CASE_TO_LOWER_CASE_WITH_UNDERSCORES 를이후 버전에서는 PropertyNamingSt..
아마존 리눅스 1 서버 기준EC2 서버 접속 간소화Mac 기준EC2 서버로 SSH 접속하려면 매번 pem파일과 ip를 입력해야 한다.$ ssh i {pem 키 위치} {public Ip주소}~/.ssh/ 디렉토리로 pem 파일을 옮겨 놓으면 ssh 실행 시 pem 키 파일을 자동으로 읽어 접속할 수 있다.$ cp {pem키 위치} ~/.ssh/pem키 권한 변경$ chmod 600 ~/ssh/{pem 키}pem키가 있는 ~/.ssh 디렉토리에 config 파일 생성$ vim ~/.ssh/config# myServiceName용 접근 설정 Host myServiceName HostName {public Ip 주소} User ec2-user IdentityFile ~/.ssh/myServiceName.pem..
즉시 로딩과 지연 로딩프록시 학습 처음에 했던 질문. Member를 조회할 때 Team도 함께 조회 해야 할까?비즈니스 로직에서 단순히 멤버 로직만 사용하는데 함께 조회하면, 아무리 연관관계가 걸려있다고 해도 손해이다.JPA는 이 문제를 지연로딩 LAZY를 사용해서 프록시로 조회하는 방법으로 해결 한다.코드로 이해하기Member와 Team 사이가 다대일 @ManyToOne 관계로 매핑되어 있는 상황에서,@ManyToOne 어노테이션에 fetch 타입을 줄 수 있다.FetchType.LAZY@Entity @Getter @Setter public class Member extends BaseEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY)..
프록시질문으로 부터 프록시에 대한 학습을 시작한다.Member 엔티티를 조회할 때 Team도 함께 조회해야 할까?실제로 필요한 비즈니스 로직에 따라 다르다.비즈니스 로직에서 필요하지 않을 때가 있는데, 항상 Team을 함께 가져와서 사용할 필요는 없다.낭비가 발생하게 된다.JPA는 이 낭비를 하지 않기 위해, 지연로딩과 프록시라는 개념으로 해결한다.프록시 기초지연 로딩을 이해하려면, 프록시의 개념에 대해서 명확하게 이해해야 한다.JPA에서 em.find() 말고, em.getReference()라는 메서드도 제공 된다.em.find() 는 DB를 통해서 실제 엔티티 객체를 조회하는 메서드이고em.getReference() 는 DB의 조회를 미루는 가짜(프록시) 엔티티 객체를 조회하는 메서드이다.Membe..
영속성 컨텍스트JPA를 공부할 때 가장 중요한게객체와 관계형 데이터베이스를 매핑하는 것(Object Relational Mapping) 과영속성 컨텍스트를 이해하는 것 이다. 두가지 개념은 꼭 알고 JPA를 활용하자. 엔티티 매니저 팩토리와 엔티티 매니저JPA는 스레드가 하나 생성될 때 마다(매 요청마다) EntityManagerFactory에서 EntityManager를 생성한다.EntityManager는 내부적으로 DB 커넥션 풀을 사용해서 DB에 붙는다. 영속성 컨텍스트영속성 컨텍스트는 JPA를 이해하는데 가장 중요한 용어이다."엔티티를 영구 저장하는 환경"이라는 뜻EntityManager.persist(entity);앞의 예제에서 persist()로 db에 객체를 저장하는 것이라고 배웠지만,실제로..
@MappedSuperclass객체의 입장에서 공통 매핑 정보가 필요할 때 사용한다.id, name은 객체의 입장에서 볼 때 계속 나온다.이렇게 공통 매핑 정보가 필요할 때, 부모 클래스에 선언하고 속성만 상속 받아서 사용하고 싶을 때 @MappedSuperclass를 사용한다.DB 테이블과는 상관없다. 아래에 보면 DB는 매핑 정보 다 따로 쓰고 있다. 객체의 입장이다.코드로 이해하기생성자, 생성시간, 수정자, 수정시간을 모든 엔티티에 공통으로 가져가야 하는 상황에서아래와 같이 BaseEntity를 정의해서 활용할 수 있다.BaseEntity.java매핑정보만 상속받는 Superclass라는 의미의 @MappedSuperclass 어노테이션 선언@Getter @Setter @MappedSuperclas..
- Total
- Today
- Yesterday
- Raspberry Pi
- Spring
- github
- Spring Boot
- Wisoft
- IT융합인력양성사업단
- 알고리즘
- Algorithm
- 정렬
- 레드블랙트리
- 시간복잡도
- Recursion
- springboot
- 한밭이글스
- 무선통신소프트웨어연구실
- 젠킨스
- 자바
- Vue.js
- RBT
- 인프런
- JPA
- vuejs
- AWS
- ORM
- 한밭대학교
- 라즈베리파이
- vuex
- Java
- 스프링부트
- 순환
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |