엔티티의 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)
는 totalWaiting2
와 totalWaiting1
을 비교하고 결과를 반환합니다.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을 사용할 수 있습니다.
아래는 세 가지 방법을 각각 사용한 예입니다.
- JPQL을 사용:
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(); }
- Native Query를 사용:
경우에 따라서 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
필드명이 실제 데이터베이스의 테이블명과 일치하는 것으로 가정합니다.- Spring Data JPA Projections:
Spring Data JPA의 Projections 기능을 사용하여 레포지토리 메서드에 반환 유형을 지정합니다.
List<ContractProjection> findAllBy();
위에서 정의한
ContractProjection
인터페이스를 사용하면 됩니다.위의 방법 중 하나를 선택하여
ContractRepository
에 메서드를 추가한 후, 원하는 필드만을 조회하도록 코드를 수정하면 됩니다.