JAVA 스킬

JAVA 스킬

생성일
Feb 10, 2023 08:42 AM
최종 편집 일시
Last updated October 16, 2024
태그
JAVA
 
엔티티의 equlas and hascode 메서드를 패턴 매칭을 이용해 작성할 수 있다.
이를 이용해 다양한 패턴 조건을 줄 수 있다. 이는 개발 시간과 코드 양을 줄여주는 방법이다. 그리고 타입 안전한 코드를 작성할 수 있도록 도와준다. 또한 맵 리듀싱 방법을 통해 데이터 스트림을 다룰 수 있는 방법도 있다.
@Override public boolean equals(Object o) { if (this == o) return true; if (!(o instanceof ArticleComment that)) return false; return id != null && id.equals(that.id); }
 

리스트의 정렬

Java에서의 리스트 정렬은 주로 Collections.sort() 또는 List.sort() 메서드를 사용합니다. 이 메서드들은 정렬 알고리즘을 내부적으로 구현하고 있습니다. 기본적으로 이 알고리즘은 "합병 정렬(Merge Sort)"에 기반한 TimSort라는 알고리즘을 사용합니다.
정렬 방향(오름차순 또는 내림차순)은 우리가 제공하는 비교 로직에 따라 달라집니다. Java에서 비교 로직은 주로 Comparator 인터페이스를 사용하여 구현됩니다.
아래의 예제 코드에서:
sortedList.sort((o1, o2) -> { long totalWaiting1 = o1.getBuyWaiting() + o1.getSellWaiting(); long totalWaiting2 = o2.getBuyWaiting() + o2.getSellWaiting(); return Long.compare(totalWaiting2, totalWaiting1); // 내림차순 });
Comparator를 람다 표현식으로 구현하였습니다. Long.compare(totalWaiting2, totalWaiting1)totalWaiting2totalWaiting1을 비교하고 결과를 반환합니다.
  • totalWaiting2 > totalWaiting1 일 경우 양수 반환
  • totalWaiting2 < totalWaiting1 일 경우 음수 반환
  • totalWaiting2 == totalWaiting1 일 경우 0 반환
정렬 알고리즘이 이 비교 결과를 기반으로 요소의 순서를 결정합니다. 위 코드는 totalWaiting2가 더 크면 양수를 반환하기 때문에 내림차순으로 정렬됩니다.
만약 오름차순으로 정렬하려면, Long.compare(totalWaiting1, totalWaiting2)와 같이 인자의 순서를 바꾸면 됩니다.
 
결론: 양수인 놈이 먼저 나오게 되므로 내림차순임.
 

jpaRepository에서 projection 인터페이스 사용하는 방법

JPA와 Spring Data JPA를 사용할 때, 특정 필드만을 조회하기 위해서는 JPQL, Native Query, 또는 Spring Data JPA의 Projections을 사용할 수 있습니다.
아래는 세 가지 방법을 각각 사용한 예입니다.
  1. JPQL을 사용:
    1. ContractRepository 인터페이스에 custom query를 정의할 수 있습니다.
      @Query("SELECT c.contractId AS contractId, c.name AS name FROM Contract c") List<ContractProjection> findContractIdAndName();
      여기서 ContractProjection은 다음과 같이 인터페이스로 정의됩니다.
      public interface ContractProjection { Long getContractId(); String getName(); }
  1. Native Query를 사용:
    1. 경우에 따라서 JPQL 대신 Native Query를 사용할 수도 있습니다.
      @Query(value = "SELECT c.contract_id AS contractId, c.name AS name FROM contracts c", nativeQuery = true) List<ContractProjection> findContractIdAndName();
      여기에서는 contracts 테이블명과 contract_id 필드명이 실제 데이터베이스의 테이블명과 일치하는 것으로 가정합니다.
  1. Spring Data JPA Projections:
    1. Spring Data JPA의 Projections 기능을 사용하여 레포지토리 메서드에 반환 유형을 지정합니다.
      List<ContractProjection> findAllBy();
      위에서 정의한 ContractProjection 인터페이스를 사용하면 됩니다.
위의 방법 중 하나를 선택하여 ContractRepository에 메서드를 추가한 후, 원하는 필드만을 조회하도록 코드를 수정하면 됩니다.