인프런 커뮤니티 질문&답변

영한노게임님의 프로필 이미지
영한노게임

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

페치 조인 1 - 기본

sql distinct 질문

해결된 질문

작성

·

78

0

sql distinct는 완전히 같은 것의 중복을 제거해준다고 배웠습니다.

id를 사용한다는 가정에서 완전히 같을 경우가 존재할 수 있나요?

jpql distinct 키워드는 sql distinct에 더불어 엔티티 중복을 피하게 해주는데 sql distinct는 필요없는 과정이 아닌가 싶었습니다.

답변 2

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 영한노게임님

AI가 답변을 잘 해주었는데요.

추가로 말씀드리자면 결과적으로 데이터베이스 SQL의 결과가 같은 경우에 중복을 제거해줍니다.

이 경우 DB의 결과 자체가 줄어들기 때문에 DB -> 애플리케이션으로 전송되는 중복 데이터도 줄어들겠지요?

감사합니다.

0

안녕하세요, 인프런 AI 인턴입니다. 영한노게임님 질문에 답변을 드리겠습니다.

SQL에서의 DISTINCT는 모든 열의 값을 비교하여 일치하는 중복 레코드를 제거합니다. 즉, 모든 열이 동일한 경우에만 레코드가 중복으로 간주됩니다. 따라서 ID 같은 고유 값을 사용하지 않는 열의 경우 동일한 데이터가 있을 수 있지만, 일반적으로 데이터베이스의 설계 원칙상 식별자(ID)는 고유하게 설계되기 때문에 완전하게 동일한 레코드가 있다는 것은 일반적이지 않은 경우입니다.

JPA에서의 JPQL DISTINCT는 SQL의 DISTINCT 외에도 애플리케이션 레벨에서 엔티티 중복을 제거하는 추가적인 기능을 제공합니다. 이는 동일한 데이터에 대해 중복된 엔티티 객체를 반환하지 않도록 보장합니다. JPA의 DISTINCT는 JPQL 쿼리로부터 동일한 식별자를 가진 레코드라도 중복된 엔티티 목록에 나타나지 않도록 처리합니다.

이러한 이유로 일반 SQL DISTINCT와는 약간의 차이가 있으며, JPQL DISTINCT를 사용하면 영속성 컨텍스트 내에서 중복되는 엔티티 인스턴스 생성을 방지한다는 점에서 유용할 수 있습니다.

아래의 유사한 질문을 통해 자세한 설명을 참고하실 수 있습니다:
- “distinct에 대한 이해”
- “Distinct 와 Set 사용에 대해서 질문이 있습니다.”

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

영한노게임님의 프로필 이미지
영한노게임

작성한 질문수

질문하기