MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java 对象)映射成数据库中的记录。
1. SqlSessionFactory
SqlSessionFactory对象是使用MyBatis的应用程序的核心,SqlSession都需要通过SqlSessionFactory实例来获取。构造SqlSessionFactory有两种方式, xml和java 两种方式。
首先创建xml配置文件,一个简单的配置(以MySQL为例)
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/test"></property>
<property name="username" value="root"></property>
<property name="password" value="xxxxxx"></property>
</dataSource>
</environment>
</environments>
</configuration>
这里我们创建了SqlSessionFactory可以依赖的环境(包括数据源和事务管理),可以创建多个environment,但需要指定其中的一个为默认的环境。
简要说明下transactionManager和dataSource的type代表的意思,
transactionManager的type可选值为:
JDBC #代表 org.apache.ibatis.transaction.jdbc.JdbcTransactionFactory
MANAGED #代表 org.apache.ibatis.transaction.managed.ManagedTransactionFactory
dataSource的type可选值为:
JNDI #代表org.apache.ibatis.datasource.jndi.JndiDataSourceFactory
POOLED #代表org.apache.ibatis.datasource.pooled.PooledDataSourceFactory
UNPOOLED #代表 org.apache.ibatis.datasource.unpooled.UnpooledDataSourceFactory
配置文件里面还可以配置其他很多地方,在以后的章节我们再做描述。
根据xml配置构建SqlSessionFactory, 我们这里使用SqlSessionFactoryBuilder来构建SqlSessionFactory。
String configurationResource = "mybatis-configuration.xml";
InputStream inputStream = Resources.getResourceAsStream(configurationResource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
inputStream.close();
- Java 方式创建SqlSessionFactory(其实就是将xml中配置的信息转换到Java代码里)
DataSource dataSource = new PooledDataSource("com.mysql.jdbc.Driver","jdbc:mysql://localhost:3306/test","root","123456");
Environment environment = new Environment("develop",new JdbcTransactionFactory(),dataSource);
Configuration configuration = new Configuration(environment);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);
2. SqlSession
SqlSession 提供了以数据库为背景的所有SQL操作的方法。SqlSession可以从SqlSessionFactory中获取,SqlSessionFactory提供了多种方式来获取一个SqlSession。
SqlSession openSession();
SqlSession openSession(boolean autoCommit);
SqlSession openSession(Connection connection);
SqlSession openSession(TransactionIsolationLevel level);
SqlSession openSession(ExecutorType execType);
SqlSession openSession(ExecutorType execType, boolean autoCommit);
SqlSession openSession(ExecutorType execType, TransactionIsolationLevel level);
SqlSession openSession(ExecutorType execType, Connection connection);
这里我们直接使用默认的SqlSession获取方法:
SqlSession sqlSession = sqlSessionFactory.openSession();
try{
List<Map> list = sqlSession.selectList("org.antstudio.mybatis.test.ConfigurationTest.selectTest");
}finally{
sqlSession.close();
}
这里我们使用sqlSession查询出了一个列表,注意,sqlSession为非线程安全的对象,其使用范围最好为一个请求或者一个方法范围内。
3. MappedStatement
MyBatis将sql语句、参数、结果处理等一系列相关的元素封装成一个一个的已映射的sql(MappedStatement), 在上面我们通过sqlSession来查询了一个列表,要使这段代码正常运行,还需要配置或者定义相关的MappedStatement。 MappedStatement可以通过xml配置或者Java方式显示添加。
新建一个ConfigurationTestMapper.xml.xml
<?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="org.antstudio.mybatis.test.ConfigurationTest">
<select id="selectTest" resultType="HashMap">
select * from tab_user
</select>
</mapper>
每一个MappedStatement的唯一标示为namespace+id,如果注册重复的MappedStatement则会抛出异常。
然后在mybatis-configuration.xml配置文件中添加如下语句:
<mappers>
<mapper resource="ConfigurationTestMapper.xml"></mapper>
</mappers>
将配置的映射添加进来。
如同SqlSessionFactory的java构造一样,需要提供xml构造时的所有的信息。
SqlSource sqlSource1 = new StaticSqlSource(configuration,"select * from tab_user");
final ResultMap resultMap = new ResultMap.Builder(configuration,"org.antstudio.mybatis.test.Configuration.selectTest",HashMap.class,new ArrayList<ResultMapping>()).build();
MappedStatement mappedStatement = new MappedStatement.Builder(configuration,"org.antstudio.mybatis.test.Configuration.selectTest",sqlSource, SqlCommandType.SELECT)
.resultMaps(new ArrayList<ResultMap>(){{add(resultMap);}}).build(); //定义一个mappedStatement,每行用HashMap包装--》等同于xml中的resultType="HashMap"
configurationWithoutXml.addMappedStatement(mappedStatement);//添加到configuration
这样就具备了MyBatis可以简单运行的所有必备元素,这里主要简单介绍了MyBatis的基本的元素和配置。具体源码见: https://gist.github.com/gavincook/4471c06138976bf1284c