日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發布時間:2024/4/13 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。