반응형
1. 개요
- Connection을 생성한 상태에서 Controller, Service, Repository, Mapper 구조를 통해 DB 데이터를 Select 하자
- Controller, Service, Repository 클래스에 대한 자세한 설명은 하지 않겠다.
2. 준비
- postgreSQL DB의 Select 테이블
- mybatis 연동 경험
3. Controller 생성
- 먼저 클라이언트의 요청을 받을 Controller 클래스를 생성한다.
- 필자는 각각 Controller, Service, Repository 모두 각각의 패키지를 만든 후 생성했다.
- test-select로 오는 get 요청에 대해 testService 인터페이스 구현체 응답값을 리턴하도록 하였다.
@Controller
public class TestController {
@Autowired
private TestService testService;
@GetMapping("/test-select")
@ResponseBody
public List<BoardDto.Info> testSelect(){
return testService.testSelect();
}
}
4. ServiceInterface 생성
- 서비스 인터페이스를 생성한다.
public interface TestService {
public List<BoardDto.Info> testSelect();
}
5. Service 구현체 생성
- TestService Interface의 구현체 클래스를 생성한다.
- TestRepository를 Autowired 한다.
@Service
public class TestServiceImpl implements TestService{
@Autowired
private TestRepository testRepository;
@Override
public List<Info> testSelect() {
return testRepository.testSelect();
}
}
6. TestRepository 인터페이스 생성
- 리포지토리 인터페이스를 생성한다.
- 이 클래스는 인터페이스이기때문에 @Repository만 입력 시 구현체가 없으므로 Service 클래스에서 TestRepository를 주입에 실패했다는 에러가 발생한다. @Mapper 어노테이션은 이러한 인터페이스를 mybatis의 매퍼로 등록해주기 위해 사용된다. 즉 Mapper Bean이 되는것이다.
@Repository
@Mapper
public interface TestRepository {
public List<Info> testSelect();
}
- 하지만 이렇게 Mapper 어노테이션을 명시적으로 선언하게 되면 생성되는 모든 Repository에 다 넣어줘야한다. 이게 귀찮다면 DatabaseConfig 클래스에 @MapperScan("패키지 경로") 어노테이션을 선언해주자. 그럼 패키지 경로에 포함된 인터페이스에 대해 @Mapper 어노테이션을 선언한 효과를 얻을 수 있다.
@Configuration
@MapperScan("com.modu.repository")
public class DatabaseConfig {
...
}
7. TestMapper 생성
- Mapper.xml을 생성한다.
- 필자의 경우 Dto 클래스를 static inner class 형식으로 사용하기 때문에 resultType에 $가 포함되어 있다. 만약, static inner class를 사용하지 않는다면 패키지 경로를 넣어주면 된다.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.modu.repository.TestRepository">
<select id="testSelect" resultType ="com.modu.dto.BoardDto$Info">
SELECT
board_seq
,cat_id
,title
,content
,writer
,create_date
,update_date
FROM
tbl_board
</select>
</mapper>
8. 테스트
9. 마치며
- hikariCP와 mybatis, postgreSQL을 연동해보았는데 그저 머릿속에 있는 DB 통신에 대한 패턴을 별 생각없이 구현했다. DB 설정 클래스의 bean들은 각각 역할을 하는지, Mapper.xml 파일에 등록한 쿼리는 내부적으로 어떻게 생성되어 실제 쿼리가 처리되는지, Repository 인터페이스와 Mapper의 id가 어떻게 매핑되는지가 궁금해졌다. 다음 포스팅에서는 이런 설정 하나하나가 시스템적으로 어떻게 돌아가는지 알아봐야겠다.
반응형
'백엔드 > SpringBoot' 카테고리의 다른 글
[SpringBoot] hikariCP + PostgreSQL + mybatis 연동하기 (1) (0) | 2021.11.12 |
---|---|
[SpringBoot] 스프링 부트 로그 남기기 / LogBack (3) | 2021.10.07 |