Getting Started
This chapter will show you in a few steps how to install and setup MyBatis-CDI.
Installation
To use the MyBatis-CDI module, you just need to include the mybatis-cdi-2.1.1-SNAPSHOT.jar
file and its dependencies in the classpath.
If you are using Maven just add the following dependency to your pom.xml
:
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-cdi</artifactId>
<version>2.1.1-SNAPSHOT</version>
</dependency>
Quick Setup
First, switch CDI on by adding a beans.xml
file to your META-INF
directory.
Next, to use MyBatis with CDI you need to provide at least two things:
an SqlSessionFactory
and a CDI bean that requires a MyBatis mapper injection.
Create a producer method that returns an application scoped SqlSessionFactory
annotated with @SessionFactoryProvider
:
import jakarta.enterprise.inject.Produces;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.cdi.SessionFactoryProvider;
public class SqlSessionFactoryProvider {
@Produces
@ApplicationScoped
@SessionFactoryProvider
public SqlSessionFactory produceFactory() {
SqlSessionFactory factory = create the factory instance ....
return factory;
}
}
Assume you have a mapper interface defined like the following (Note that the mapper must be annotated with @Mapper
):
@Mapper
public interface UserMapper {
@Select("SELECT * FROM users WHERE id = #{userId}")
User getUser(@Param("userId") String userId);
}
You can inject it into a CDI bean just as any other dependency using @Inject
:
import jakarta.inject.Inject;
public class FooServiceImpl implements FooService {
@Inject UserMapper userMapper;
public User doSomeStuff(String userId) {
return this.userMapper.getUser(userId);
}