defined in @EnableJpaRepositories 오류
8707
작성한 질문수 10
안녕하세요 강사님!
강사님의 스프링과 jpa 강의를 듣고 프로젝트를 만드는 중인 학생입니다. 다름이 아니라 따로 좋아요 기능을 추가해서 학습한 내용을 바탕으로 제작 중인데
Error creating bean with name 'likeApiController' defined in file [/Users/gimnayeon/Desktop/GreenProject/GrinGreen/out/production/classes/com/grin/GrinGreen/api/LikeApiController.class]: Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'likeService' defined in file [/Users/gimnayeon/Desktop/GreenProject/GrinGreen/out/production/classes/com/grin/GrinGreen/service/LikeService.class]: Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'likeRepository' defined in com.grin.GrinGreen.repository.LikeRepository defined in @EnableJpaRepositories declared on JpaRepositoriesRegistrar.EnableJpaRepositoriesConfiguration: Invocation of init method failed; nested exception is org.springframework.data.repository.query.QueryCreationException: Could not create query for public abstract java.util.Optional com.grin.GrinGreen.repository.LikeRepository.findBybusiness(com.grin.GrinGreen.domain.Member,com.grin.GrinGreen.domain.Business)! Reason: Failed to create query for method public abstract java.util.Optional com.grin.GrinGreen.repository.LikeRepository.findBybusiness(com.grin.GrinGreen.domain.Member,com.grin.GrinGreen.domain.Business)! At least 2 parameter(s) provided but only 1 parameter(s) present in query.; nested exception is java.lang.IllegalArgumentException: Failed to create query for method public abstract java.util.Optional com.grin.GrinGreen.repository.LikeRepository.findBybusiness(com.grin.GrinGreen.domain.Member,com.grin.GrinGreen.domain.Business)! At least 2 parameter(s) provided but only 1 parameter(s) present in query.
라는 오류가 뜹니다.
LikeRepository
@Transactional(readOnly = true)
public interface LikeRepository extends JpaRepository<Like, Long> {
Optional<Integer> countBybusiness(Business business);
Optional<Like> findBybusiness(Member member, Business business);
}business entity
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "mail")
private Member member;
@OneToMany(mappedBy = "business", cascade = CascadeType.ALL)
Set<Like> likes = new HashSet<>();member entity
@OneToMany(mappedBy = "member", cascade = CascadeType.ALL)
private List<Business> business = new ArrayList<>();
@OneToMany(mappedBy = "member", cascade = CascadeType.ALL)
Set<Like> likes = new HashSet<>();like entity
@Id
@GeneratedValue
@Column(name = "like_id")
private Long id;
@ManyToOne(fetch = FetchType.LAZY)
private Member member;
@ManyToOne(fetch = FetchType.LAZY)
private Business business;
public Like(Business business, Member member) {
this.business = business;
this.member = member;
}
처음에는 jparepository에서 findBy 이후 대문자를 쓴 게 문제였나 싶어 수정을 했지만 아니었고
파라미터의 Id처럼 대문자로 쓰여진 게 문제인가 봤지만 해당 사항이 없었습니다..
아무리 강의를 돌려봐도 감이 안 잡히는 데 어디 부분의 문제일까요?ㅠㅠ
파라메터 값이 2개인데 1개만 받아졌다는 오류인 것도 같습니다....
답변 1
2
안녕하세요. 김도연님, 공식 서포터즈 David입니다.
우선, findByBusiness로 변경해주세요. 메서드 생성 관례는 camel case입니다.
Member와 Business로 Like를 찾으시려면 findByBusinessAndMember로 작성해보시겠어요?
감사합니다.
강의 관련 외 질문입니다.
0
83
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
1
101
1
BeanCreationException
0
98
3
Update 후 UpdateMemberResponse 매핑할 때
0
58
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
103
2
페이징 + 검색조건 관련해서 질문드립니다.
0
74
1
Query Dsl Q파일 질문입니다.
0
86
1
루트 쿼리라는것은
0
62
1
메서드를 분리하는 기준
0
71
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
116
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
92
2
fetch join과 영속화와 OSIV의 관계
0
92
2
Distinct 사용 전 결과에 대한 의문
0
120
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
63
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
79
2
dto 필드 속 엔티티 여부
0
63
1
뷰템플릿 사용 시
0
82
2
Result 클래스 관련 질문
0
58
1
@PostConstruct 프록시 관련 질문드립니다
0
88
1
DTO 대신 Form 사용은 안되나요?
0
140
1
OSIV ON 상태일 때
0
100
1
fetch join VS fetch join 페이징 궁금증
0
191
2
양방향 연관관계 알아보는 법?
0
110
1
16강 17강 간단 정리 이게 맞을까요 ?
0
169
2





