Spring

    Spring Boot :: @FeignClient 로 외부 REST API 간편 호출

    Spring Boot :: @FeignClient 로 외부 REST API 간편 호출

    들어가면서 카카오 및 애플 로그인을 구현하면서 외부 API 서버에 접근해 데이터를 받아와야 하는 일이 많아졌고, API 주소를 설정파일에 저장한 후 직접 HttpURLConnection 을 생성해서 연결하는 코드가 중복되게 되었다. 또 직접 HttpURLConnection 을 연결해 외부 API 에서 데이터를 받아오면 받아온 JSON 을 직접 파싱해야 하는 불편함도 존재했다. 정리하자면, 외부 API 를 간편하게 호출하고 싶어서 호출 결과를 직접 파싱하는 과정이 번거로워서 FeignClient 를 사용하게 되었다. 아래 설명에서는 많이 예시를 드는 Github API 를 이용해서 코드를 작성해보았다. FeinClient Feign 은 Netflix 에서 개발한 REST Client 이다. 기존에 Rest..

    JPA :: 벌크성 수정 쿼리

    JPA :: 벌크성 수정 쿼리

    벌크 연산 여러 건의 데이터를 한 번에 수정하거나 삭제 조건에 맞는 객체를 다 가지고 와서 수정할 필요 없이 DB 쿼리로 해결하는 것. JPA Bulk 예제 코드 : 파라미터로 받은 나이보다 많은 회원들의 나이를 +1 시킨다. public int bulkAgePlus(int age) { return em.createQuery( "update Member m set m.age = m.age + 1" + " where m.age >= :age") .setParameter("age", age) .executeUpdate(); } 테스트 코드 @Test public void bulkUpdate() { //given memberJpaRepository.save(new Member("member1", 10)); m..

    JPA :: 페이징과 정렬

    JPA :: 페이징과 정렬

    기존 JPA 페이징과 정렬 public List findByPage(int age, int offset, int limit) { return em.createQuery("select m from Member m where m.age = :age order by m.username desc") .setParameter("age", age) .setFirstResult(offset) .setMaxResults(limit) .getResultList(); } public long totalCount(int age) { return em.createQuery("select count(m) from Member m where m.age = :age", Long.class) .setParameter("age", a..

    JPA :: Query Method 기능

    JPA :: Query Method 기능

    스프링 데이터 JPA 가 제공하는 마법같은 기능이 있다. 바로 “쿼리 메소드” 기능인데, 결론부터 말하면 3가지 기능이 있다. 메소드 이름으로 쿼리 생성 메소드 이름으로 JPA NamedQuery 호출 @Query 어노테이션을 사용해서 Repository interface 에 쿼리 직접 정의 Method 이름으로 Query 생성 메소드 이름을 분석해서 JPQL 쿼리 실행 예) 이름과 나이를 기준으로 회원을 조회하려면 ? // 순수 JPA Repository public List findByUsernameAndAgeGreaterThan(String username, int age) { return em.createQuery("select m from Member m where m.username = :us..

    Spring Boot :: Spring Data 패키지 구조

    Spring Boot :: Spring Data 패키지 구조

    Spring Data JPA 를 활용해서 인터페이스를 사용할 때 JpaRepository 를 상속받아서 사용한다. 이 JpaRepository 안에 들어가면 또 다른 Repository 를 상속받고 또 상속받고 ,, 이 구조에 대해서 기록해두고자 한다. 인터페이스 살펴보기 먼저 MemberRepository 라는 레포지토리를 만들어보았다. public interface MemberRepository extends JpaRepository { } 여기서 JpaRepository 안에 들어가보자. 패키지 위치는 org.springframework.data.jpa.repository 이다. JpaRepository 는 PagingAndSortingRepository 를 상속받고 있고, PagingAndSort..

    Spring Boot :: Spring Data JPA

    Spring Boot :: Spring Data JPA

    인터페이스만 정의해도 CRUD 기능을 사용할 수 있다 ? 테스트 코드를 통해서 CRUD 기능이 동작하는지 간단하게 테스트해보자. 테스트 순서 Entity 생성 순수 JPA Repository 생성 후 테스트 Data JPA Repository 생성 후 테스트 Entity 생성 먼저 Member Entity 를 만들자. @Entity @Getter @Setter @NoArgsConstructor(access = AccessLevel.PROTECTED) @ToString(of = {"id", "username"}) public class Member { @Id @GeneratedValue @Column(name = "member_id") private Long id; private String usernam..

    Spring Boot :: JPA란?

    Spring Boot :: JPA란?

    이동욱님의 스프링 부트와 AWS 로 혼자 구현하는 웹 서비스 와 인프런 김영한님의 자바 ORM 표준 JPA 프로그래밍 기본편 을 보다가 JPA 에 대해 이해하기 쉽게 설명된 부분이 있어 인용해서 적어보았다. 웹 서비스를 개발하면서 피할 수 없는 문제는 DB 를 다루는 일이다. 특히 백엔드 개발자를 희망하고 공부하면서 느끼는 점은 DB를 다룰 일이 생각보다 많다는 것. 당장 백엔드 프레임워크를 이용해서 어플리케이션 개발에 몰두하기에도 시간이 부족한데, DB는 또 언제 공부하는지.. 어쨌든 RDB 를 이용하는 프로젝트에서 어떻게 객체지향 프로그래밍을 할 수 있을까 에 대한 해답으로 JPA 라는 자바 표준 ORM (Object Relational Mapping) 기술을 만나게 된다. 참고로 MyBatis, i..