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

권은지님의 프로필 이미지
권은지

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

JPA

result.stream().findAny() 쓰는 이유

작성

·

473

0

안녕하세요

findByName, findById 메소드에서

왜 결과값을 리스트로 받아와서 리턴을 stream().findByAny()로 하시는지 궁금합니다.

저는 마이바티스만 써봐서 마이바티스의 경우 Member객체로 결과값이 반환이 되는데 jpa는 그렇게 안되는 걸까요?

아니면 특별한 이유가 있는 걸까요?

강의 잘 듣고있습니다 감사합니다:)

답변 2

2

안녕하세요. 권은지님, 공식 서포터즈 OMG입니다.

findByName, findById 메소드에서

왜 결과값을 리스트로 받아와서 리턴을 stream().findByAny()로 하시는지 궁금합니다.

리스트로 받는 이유는 결과값이 1개가 넘을 수도 있기 때문에 List로 해당 타입의 객체를 받도록 한 것입니다. 그리고 결과 값을 최대 1개만 반환하기 위해 이름 기준으로 찾게 될 경우 findAny()에 의헤 해당 객체를 반환하고 메서드는 종료됩니다.

추가적으로 자바8부터 도입된 Optional과 stream에 대해서 학습하시는걸 권장드립니다.

저는 마이바티스만 써봐서 마이바티스의 경우 Member객체로 결과값이 반환이 되는데 jpa는 그렇게 안되는 걸까요?

JPA도 객체를 반환할 수 있으며, 마이바티스도 List, Map 등으로 반환 할 수 있습니다.

- Blog 객체를 List로 반환

출처: https://mybatis.org/mybatis-3/ko/dynamic-sql.html

감사합니다.

권은지님의 프로필 이미지
권은지
질문자

@OMG 안녕하세요 답변 감사합니다:)

여기 추가적인 질문을 하면 OMG님에게 알람이 가는 걸까요?

제가 궁금한 건 findAny를 쓰는 이유였습니다!

findByName이나 findById는 중복값이 없기 때문에 결과값이 1개를 넘지 않을 것이라고 생각했는데 아닌가요?

그리고 만약 시스템상 오류로 이름이 중복으로 들어간다면 2개의 값이 반환될 것이고, 그 상황에서 findAny 메소드를 사용해 한 객체만 반환한다면 그것 역시 오류가 아닌 지 궁금합니다.

1

Q. findByName이나 findById는 중복값이 없기 때문에 결과값이 1개를 넘지 않을 것이라고 생각했는데 아닌가요?

A.  JPA에서는 다음과 같이 @Id를 통해 식별자로 선언하고, @GeneratedValue를 통해 자동 증가 하는 값(MySql의 경우 auto_increment, Oracle이면 Sequence 겠죠?) 을 지정해줄 수 있습니다.

그렇기 때문에 Id에서는 JPA 내에서 중복이 발생하지 않게 설계가 가능합니다.

name 등 다른 필드에 대해서는 @Column 에노테이션에 unique 속성을 지정해서 유니크 제약조건을 걸 수 있습니다.  name과 같은 필드의 경우 unique를 지정하지 않는다면 중복된 데이터가 들어갈 수 있습니다.

@Entity
public class Person {
@Id @GeneratedValue
private long id;

@Column(name = "name", unique = true)
private String name;

public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

Q. 그리고 만약 시스템상 오류로 이름이 중복으로 들어간다면 2개의 값이 반환될 것이고, 그 상황에서 findAny 메소드를 사용해 한 객체만 반환한다면 그것 역시 오류가 아닌 지 궁금합니다.

A. 그럴 일은 없겠지만 바로 위에서 제가 답변한 설정에 문제가 생긴다면 권은지님이 말씀하신 상황은 오류라고 볼 수 있겠네요.

JPA에 대해 관심이 많으신 것 같은데 영한님의  JPA 기본편 학습을 추천드립니다.

감사합니다.

권은지님의 프로필 이미지
권은지

작성한 질문수

질문하기