MyBatis创建SqlSession-怎么拿到一个SqlSessionTemplate?
我們知道在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@Autowiredprivate SqlSessionFactory sqlSessionFactory;@Autowiredpublic 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 {@Overridepublic 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 的方法。
?
總結
以上是生活随笔為你收集整理的MyBatis创建SqlSession-怎么拿到一个SqlSessionTemplate?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MyBatis创建SqlSession可
- 下一篇: MyBatis创建SqlSession-