Mybatis入门(一)

MyBatis的前身叫iBatis,本是apache的一个开源项目, 2010年这个项目由apache software foundation 迁移到了google code,而且更名为MyBatis。MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎全部的JDBC代码和参数的手工设置以及结果集的检索。MyBatis使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plan Old Java Objects,普通的Java对象)映射成数据库中的记录。java

Mybatis的功能架构分为三层mysql

1)       API接口层:提供给外部使用的接口API,开发人员经过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。sql

2)       数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操做。数据库

3)      基础支撑层:负责最基础的功能支撑,包括链接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来做为最基础的组件。为上层的数据处理层提供最基础的支撑。apache

如今来看看三个重要的类
缓存

SqlSessionFactoryBuilder安全

每个MyBatis的应用程序的入口是SqlSessionFactoryBuilder,它的做用是经过XML配置文件建立Configuration对象(固然也能够在程序中自行建立),而后经过build方法建立SqlSessionFactory对象。没有必要每次访问Mybatis就建立一次SqlSessionFactoryBuilder,一般的作法是建立一个全局的对象就能够了。session

SqlSessionFactorymybatis

SqlSessionFactory对象由SqlSessionFactoryBuilder建立。它的主要功能是建立SqlSession对象,和SqlSessionFactoryBuilder对象同样,没有必要每次访问Mybatis就建立一次SqlSessionFactory,一般的作法是建立一个全局的对象就能够了。SqlSessionFactory对象一个必要的属性是Configuration对象,它是保存Mybatis全局配置的一个配置对象,一般由SqlSessionFactoryBuilder从XML配置文件建立架构

SqlSession

SqlSession对象的主要功能是完成一次数据库的访问和结果的映射,它相似于数据库的session概念,因为不是线程安全的,因此SqlSession对象的做用域需限制方法内。SqlSession的默认实现类是DefaultSqlSession,它有两个必须配置的属性:Configuration和Executor。Configuration前文已经描述这里再也不多说。SqlSession对数据库的操做都是经过Executor来完成的,Executor的具体功能在下一小节在描述。

到目前为止,咱们看到的都是mybatis的流程,咱们的应用程序在什么地方插入到这个流程中并得到咱们想要的结果呢?就是SqlSession这里。SqlSession有一个重要的方法getMapper,顾名思义,这个方式是用来获取Mapper对象的。什么是Mapper对象?根据Mybatis的官方手册,应用程序除了要初始并启动Mybatis以外,还须要定义一些接口,接口里定义访问数据库的方法,存放接口的包路径下须要放置同名的XML配置文件。SqlSession的getMapper方法是联系应用程序和Mybatis纽带,应用程序访问getMapper时,Mybatis会根据传入的接口类型和对应的XML配置文件生成一个代理对象,这个代理对象就叫Mapper对象。应用程序得到Mapper对象后,就应该经过这个Mapper对象来访问Mybatis的SqlSession对象,这样就达到里插入到Mybatis流程的目的

package org.heinrich.app;

import java.io.Reader;
import java.util.List;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.heinrich.app.dao.IUserDao;
import org.heinrich.app.domain.User;

public class MyBatisTest {
	
	public static void main(String[] args) throws Exception {
		
		
		Reader reader = Resources.getResourceAsReader("MyBatisConfig.xml");//获取资源文件
		//建立sqlSessionFactoy对象
		SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
		//获取并打开session
		SqlSession openSession = sqlSessionFactory.openSession();
		IUserDao mapper = openSession.getMapper(IUserDao.class);
		List<User> all = mapper.getAll();
		System.out.println(all);
	}

}

上面就是用到三个最为重要的类

如今配置两个重要的文件MyBatisConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC" />
			<dataSource type="POOLED">
				<property name="driver" value="com.mysql.jdbc.Driver" />
				<property name="url" value="jdbc:mysql://localhost:3306/fk_test" />
				<property name="username" value="root" />
				<property name="password" value="root" />
			</dataSource>
		</environment>
	</environments>
	<mappers>
		<mapper resource="org/heinrich/app/dao/userMapper.xml"/>
	</mappers>
</configuration>

userMaper.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.heinrich.app.dao.IUserDao">
 
 </mapper>

一个很是重要的接口,对应的是IUserDao对应的是userMapper.xml文件,一个表对应一个mapper.xml文件

package org.heinrich.app.dao;

import java.util.List;

import org.apache.ibatis.annotations.Select;
import org.heinrich.app.domain.User;

public interface IUserDao {
	
	@Select("SELECT* from user")
	public List<User> getAll();

}

上面用annotation注解方式

package org.heinrich.app;

import java.io.Reader;
import java.util.List;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.heinrich.app.dao.IUserDao;
import org.heinrich.app.domain.User;

public class MyBatisTest {
	
	public static void main(String[] args) throws Exception {
		
		
		Reader reader = Resources.getResourceAsReader("MyBatisConfig.xml");
		SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
		SqlSession openSession = sqlSessionFactory.openSession();
		IUserDao mapper = openSession.getMapper(IUserDao.class);
		List<User> all = mapper.getAll();
		System.out.println(all);
	}

}

一个简单的mybatis就搞定了

打印的值[org.heinrich.app.domain.User@54f45574, org.heinrich.app.domain.User@75165e3e]
相关文章
相关标签/搜索