MyBatis创建SqlSession-怎么拿到一个SqlSessionTemplate?

2020/12/14 23:46:08

我们知道在Spring 里面会用SqlSessionTemplate 替换DefaultSqlSession,那么接下来看一下怎么在DAO 层拿到一个SqlSessionTemplate。

不知道用过Hibernate 的同学还记不记得,如果不用注入的方式,我们在DAO 层注入一个HibernateTemplate 的一种方法是什么?

——让我们DAO 层的实现类去继承HibernateDaoSupport。

MyBatis 里面也是一样的,它提供了一个SqlSessionDaoSupport,里面持有一个SqlSessionTemplate 对象,并且提供了一个getSqlSession()方法,让我们获得一个SqlSessionTemplate。

public abstract class SqlSessionDaoSupport extends DaoSupport {
	private SqlSessionTemplate sqlSessionTemplate;
	public SqlSession getSqlSession() {
		return this.sqlSessionTemplate;
	}
前面和后面省略…………

也就是说我们让DAO 层的实现类继承SqlSessionDaoSupport ,就可以获得SqlSessionTemplate,然后在里面封装SqlSessionTemplate 的方法。

当然, 为了减少重复的代码, 我们通常不会让我们的实现类直接去继承SqlSessionDaoSupport,而是先创建一个BaseDao 继承SqlSessionDaoSupport。在BaseDao 里面封装对数据库的操作,包括selectOne()、selectList()、insert()、delete()这些方法,子类就可以直接调用。

public class BaseDao extends SqlSessionDaoSupport {
	//使用sqlSessionFactory
	@Autowired
	private SqlSessionFactory sqlSessionFactory;
	@Autowired
	public void setSqlSessionFactory(SqlSessionFactory sqlSessionFactory) {
		super.setSqlSessionFactory(sqlSessionFactory);
	}
	public Object selectOne(String statement, Object parameter) {
		return getSqlSession().selectOne(statement, parameter);
	}
	后面省略…………

然后让我们的实现类继承BaseDao 并且实现我们的DAO 层接口,这里就是我们的Mapper 接口。实现类需要加上@Repository 的注解。

在实现类的方法里面,我们可以直接调用父类(BaseDao)封装的selectOne()方法,那么它最终会调用sqlSessionTemplate 的selectOne()方法。

@Repository
public class EmployeeDaoImpl extends BaseDao implements EmployeeMapper {
	@Override
	public Employee selectByPrimaryKey(Integer empId) {
		Employee emp = (Employee)
		this.selectOne("com.leon.crud.dao.EmployeeMapper.selectByPrimaryKey",empId);
		return emp;
	}
	后面省略…………

然后在需要使用的地方,比如Service 层,注入我们的实现类,调用实现类的方法就行了。我们这里直接在单元测试类里面注入:

@Autowired
EmployeeDaoImpl employeeDao;
@Test
public void EmployeeDaoSupportTest() {
	System.out.println(employeeDao.selectByPrimaryKey(1));
}

最终会调用到DefaultSqlSession 的方法。