Java Object와 SQL문 사이의 자동 Mapping 기능을 지원하는 ORM 프레임워크이다.
MyBatis는 SQL을 그대로 이용하면서 JDBC의 코드작성 불편함을 제거해주고, 도메인 객체나 VO객체를 중심으로 개발이 가능하다.
이때 MyBatis는 SQL을 별도의 파일로 분리해서 관리하며 Object-SQL 사이의 parameter mapping 작업을 자동으로 해준다.
DB vender에서 제공하는 JDBC Driver가 있다.
JDBC만을 사용하는 어플리케이션은 Application Modules에서 JDBC 인터페이스를 바로 호출하지만 JDBC Api를 감싸서 개발자가 조금 더 편리하게 접근할 수 있도록 도와주는것이 MyBatis이다.
서비스에서 DAO를 호출하고 DAO에서 MyBatis를 사용하게 된다.
[MyBatis와 MyBatis-Spring을 사용한 DB Access 아키텍처]
MyBatis는 Data Access Layer에서 사용하는 프레임워크이다.
Controller에서 Service를 호출하고 Service가 DAO 계층에 있는 메소드를 호출하면 DAO에서 MyBatis를 호출한다.
[MyBatis를 사용하는 데이터 액세스 Layer]
MyBatis의 주요 Component로는 SqlSession Factory Builder
, SqlSession Factory
, SqlSessio
이 있다.
MyBatis 설정 파일(XML)을 작성해두고 아래 그림에서 보라색 박스부분들만 개발자가 작성하면 된다.
[MyBatis3의 주요 컴포넌트]
[MyBatis 동작하는 순서]
SqlSession Factory Builder
를 호출한다.SqlSession Factory Builder
가 설정 파일(Config file)을 읽고 Factory를 생성해준다.SqlSession Factory
가 SqlSession
을 생성하고 개발자가 작성한 Application 코드에 반환한다.SqlSession
은 개발자가 작성한 SQL문을 호출해주는 기능을 한다.SqlSessionFactoryBuilder
:SqlSessionFactory
를 생성.SqlSessionFactory
:SqlSession
을 생성한다.SqlSession
:SqlSession
객체는 Thread-Safe하지 않으므로 Thread마다 필요에 따라 생성한다.SqlSessionFactoryBean
:SqlSessionTemplate
:SqlSession Interface
를 구현하며, 객체는 Thread-Safe하다. (Spring Bean으로 등록해야 한다.)