我们知道在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 的方法。