작성
·
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
감사합니다.
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 기본편 학습을 추천드립니다.
감사합니다.
@OMG 안녕하세요 답변 감사합니다:)
여기 추가적인 질문을 하면 OMG님에게 알람이 가는 걸까요?
제가 궁금한 건 findAny를 쓰는 이유였습니다!
findByName이나 findById는 중복값이 없기 때문에 결과값이 1개를 넘지 않을 것이라고 생각했는데 아닌가요?
그리고 만약 시스템상 오류로 이름이 중복으로 들어간다면 2개의 값이 반환될 것이고, 그 상황에서 findAny 메소드를 사용해 한 객체만 반환한다면 그것 역시 오류가 아닌 지 궁금합니다.