o.s.b.d LoggingFailureAnalysisReporter 오류
506
작성한 질문수 5
2024-05-16T23:53:30.318+09:00 ERROR 11428 --- [library-app] [ restartedMain] o.s.b.d.LoggingFailureAnalysisReporter :
***************************
APPLICATION FAILED TO START
***************************
Description:
Parameter 0 of constructor in com.group.libraryapp.service.book.BookService required a bean of type 'com.group.libraryapp.domain.book.BookRepository' that could not be found.
Action:
Consider defining a bean of type 'com.group.libraryapp.domain.book.BookRepository' in your configuration.
Process finished with exit code 0
이런 오류가 뜨는데 bean 설정도 강의 내용그대로 한거 같은데 계속 코드를 수정하려고 해도 Error 가 떠서 해결방법을 모르겠습니다
package com.group.libraryapp.service.book;
import com.group.libraryapp.domain.book.Book;
import com.group.libraryapp.domain.book.BookRepository;
import com.group.libraryapp.domain.user.User;
import com.group.libraryapp.domain.user.UserRepository;
import com.group.libraryapp.domain.user.loanhistory.UserLoanHistory;
import com.group.libraryapp.domain.user.loanhistory.UserLoanHistoryRepository;
import com.group.libraryapp.dto.Book.request.BookCreateRequest;
import com.group.libraryapp.dto.Book.request.BookLoanRequest;
import com.group.libraryapp.dto.Book.request.BookReturnRequest;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service
public class BookService {
private final BookRepository bookRepository;
private final UserLoanHistoryRepository userLoanHistoryRepository;
private final UserRepository userRepository;
public BookService(
BookRepository bookRepository,
UserLoanHistoryRepository userLoanHistoryRepository,
UserRepository userRepository) {
this.bookRepository = bookRepository;
this.userLoanHistoryRepository = userLoanHistoryRepository;
this.userRepository = userRepository;
}
@Transactional
public void saveBook(BookCreateRequest request){
bookRepository.save(new Book(request.getName()));
}
@Transactional
public void loanBook(BookLoanRequest request){
Book book = bookRepository.findByName(request.getBookName())
.orElseThrow(IllegalArgumentException::new);
if(userLoanHistoryRepository.existsByBookNameAndIsReturn
(book.getName(),false)){
throw new IllegalArgumentException("이미 대출되어 있는 책 입니다");
}
User user = userRepository.findByName(request.getUsername())
.orElseThrow(IllegalArgumentException::new);
userLoanHistoryRepository.save(new UserLoanHistory(user, book.getName()));
}
@Transactional
public void returnBook(BookReturnRequest request){
User user= userRepository.findByName(request.getUserName())
.orElseThrow(IllegalArgumentException::new);
UserLoanHistory history = userLoanHistoryRepository.findByUserIdAndBookName(user.getId(), request.getBookName())
.orElseThrow(IllegalArgumentException::new);
history.doReturn();
}
}
package com.group.libraryapp.domain.book;
import org.springframework.data.jpa.repository.JpaRepository;
import java.util.Optional;
public interface BookRepository extends JpaRepository<Book,Long> {
Optional<Book> findByName(String bookName);
}
답변 1
0
안녕하세요 동찬님! 질문 올려주셔서 감사드립니다. 🙂
우선 에러를 해석해보면, com.group.libraryapp.domain.book.BookRepository 를 찾을 수 없어서, BookService 를 만들 수 없다고 하는데, 사실은 정상적으로 잘 있는 것을 확인할 수 있어요..!!
BookRepository 인터페이스도 잘 만들어주셨구요!
이런 경우는, 혹시 코드를 실행시킬 때, 이전에 컴파일 되었던 정보가 남아 있어 변경되기 전 코드로 실행되고 있는 것은 아닌지 확인해보면 좋습니다.
오른쪽 gradle 탭에서 clean을 더블클릭 한 이후, 다시 한 번 실행해보시면 좋을 것 같습니다!!

꼭 해결되셨으면 좋겠습니다. 감사합니다! 🙏
패키지 구분에 대해 궁금한게 있습니다
0
25
2
리액트 관련 질문이 있습니다.
0
64
2
스프링부트 버전
0
76
2
7강 강의를 들으려고 했는데 오류가 나서 서버가 안 켜지는거 같아요.
0
59
2
33강. UserLoanHistory의 관계성에 대한 질문
1
56
2
Java JDK 버전 문의의 건
0
135
2
ec2 에서 Linux버전이 달라져서 설치가 안되는것 같은데 자료 최신화좀 해주세요.
0
90
3
h2 console 접속했을 테이블 질문
1
66
1
ec2 서버에서 스프링 실행도 되고 인바운드 설정까지 했는데 index.html 안됨
0
79
2
15강. updateUser() 질문
0
56
2
깃허브 질
0
84
2
여기까지 다 끝냈다고 하셨는데
0
79
2
왜안될까요
0
72
2
MySQL 창이안ㄴ뜹니다
0
59
2
포스트맨
0
52
1
spring 개념적인 질문
0
71
2
인텔리제이 샘플코드 실행 안됨 오류
0
141
2
aws 배포할때 .env 파일에 저장한 환경변수에 관하여 여쭤볼게 있습니다
0
86
1
마이그레이션 오류입니다.
0
175
3
Whitelabel Error Page 오류가 났습니다.
0
166
2
안녕하십니까! 오류가 났습니다.. 도와주세요 ㅜㅜ
1
94
3
궁금한게 있습니다.
0
60
2
DTO 관련
0
70
2
궁금한게 있습니다!
0
69
2





