작성
·
93
0
강의 2분 29초 부분
public class MyBatisConfig {
private final ItemMapper itemMapper;
,,,
}
강의에서는 에러가 생기지 않지만, 이 부분에서 itemMapper에 컴파일 에러가 뜹니다.
(Could not autowire. No beans of 'ItemMapper' type found.)
ItemMapper가 스프링 컨테이너에 스프링 빈으로 등록되지 않아서 생기는 에러가 맞나요?
등록되어있지 않기 때문에 ItemMapper를 주입할 수 없어 컴파일 오류가 나는건지 궁금합니다.
그럼에도 불구하고 메모리db로 하는 테스트와, 서버를 띄워서 하는 테스트 모두 성공하는 이유가 궁금합니다.
MyBatisConfig클래스 위에 @MapperScan(basePackages = "hello.itemservice.repository.mybatis")
를 하니 컴파일 에러가 사라지긴 합니다.
@MapperScan을 통해 ItemMapper를 Bean으로 수동으로 등록하니 컴파일 오류가 생기지 않는건가요?
답변 2
0
0
안녕하세요, 인프런 AI 인턴입니다.
ctmdgus0427님께서 겪고 계신 문제와 관련하여 설명드리겠습니다. ItemMapper
가 스프링 빈으로 등록되지 않아 발생하는 컴파일 오류는 흔히 경험할 수 있는 문제입니다. 이 문제는 MyBatis 설정에서 Mapper
를 빈으로 등록하지 않을 때 발생할 수 있으며, 이를 해결하기 위한 몇 가지 중요한 포인트를 정리하였습니다.
ItemMapper 컴파일 오류 원인:
ItemMapper
가 스프링 컨테이너에 빈으로 등록되지 않았기 때문에 발생하는 오류입니다. MyBatis Mapper 인터페이스를 스프링 애플리케이션 컨텍스트에 빈으로 등록하기 위해서는 @MapperScan
어노테이션이 필요합니다.@Component
어노테이션을 통해 빈을 자동 검출하지만, MyBatis의 Mapper 인터페이스는 이러한 방식으로는 인식되지 않습니다. @MapperScan
은 지정한 패키지 내의 Mapper 인터페이스를 자동으로 스프링 빈으로 등록해줍니다.테스트가 통과하는 이유:
itemMapper
의 코드에서는 오류가 보이지만, 스프링이 전체 애플리케이션 컨텍스트를 로드하고 필요한 다른 빈들이 잘 정의되어 있다면, 전체 애플리케이션 로직에서의 종속성 문제 없이 테스트가 통과할 수 있습니다. 이는 상황에 따라 IDE(예: IntelliJ)에 보이는 ‘오류 메시지’와 실행 시 실제 동작이 일치하지 않을 수 있음을 의미합니다.@MapperScan 어노테이션:
@MapperScan
을 통해 명시적으로 패키지를 지정하여 ItemMapper
를 자동으로 빈으로 등록하면 이 문제가 해결됩니다. 이 어노테이션이 ItemMapper
를 포함한 모든 MyBatis 매퍼 인터페이스를 스프링 컨텍스트에 빈으로 주입할 수 있게 하여 컴파일 오류가 사라집니다.기존에 유사한 질문에 대한 답변과 해결 방법 링크를 제공해 드립니다:
@MapperScan
으로 MyBatis Mapper를 자동 등록하여 issue를 해결한 이야기입니다.위 링크들을 통해 더 자세한 내용을 확인하실 수 있습니다. 이 문제는 IDE 경고와 실제 실행의 불일치로 인해 혼란을 줄 수 있지만, 스프링 설정을 통해 정확히 해결할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.