Java的MyBatis+Spring框架中使用數(shù)據(jù)訪問對象DAO模式的方法
SqlSessionTemplate
SqlSessionTemplate是MyBatis-Spring的核心。這個類負(fù)責(zé)管理MyBatis的SqlSession,調(diào)用MyBatis的SQL方法,翻譯異常。SqlSessionTemplate是線程安全的,可以被多個DAO所共享使用。
當(dāng)調(diào)用SQL方法時,包含從映射器getMapper()方法返回的方法,SqlSessionTemplate將會保證使用的SqlSession是和當(dāng)前Spring的事務(wù)相關(guān)的。此外,它管理session的生命周期,包含必要的關(guān)閉,提交或回滾操作。
SqlSessionTemplate實現(xiàn)了SqlSession,這就是說要對MyBatis的SqlSession進(jìn)行簡易替換。
SqlSessionTemplate通常是被用來替代默認(rèn)的MyBatis實現(xiàn)的DefaultSqlSession,因為它不能參與到Spring的事務(wù)中也不能被注入,因為它是線程不安全的。相同應(yīng)用程序中兩個類之間的轉(zhuǎn)換可能會引起數(shù)據(jù)一致性的問題。
SqlSessionTemplate對象可以使用SqlSessionFactory作為構(gòu)造方法的參數(shù)來創(chuàng)建。
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate"> <constructor-arg index="0" ref="sqlSessionFactory"/> </bean>
這個bean現(xiàn)在可以直接注入到DAO bean中。你需要在bean中添加一個SqlSession屬性,就像下面的代碼:
public class UserDaoImpl implements UserDao{ private SqlSession sqlSession; public void setSqlSession(SqlSession sqlSession){ this.sqlSession = sqlSession; } public User getuser(String userId){ return (User)sqlSession.selectOne ("org.mybatis.spring.sample.mapper.UserMapper.getUser",userId); } }
如下注入SqlSessionTemplate:
<bean id="userDao" class="org.mybatis.spring.sample.dao.UserDaoImpl"> <property name="sqlSession" ref="sqlSession"/> </bean>
SqlSessionDaoSupport
SqlSessionDaoSupport是一個抽象的支持類,用來為你提供SqlSession。調(diào)用getSqlSession()方法你會得到一個SqlSessionTemplate,這然后可以用于執(zhí)行SQL方法,就像下面這樣:
public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao{ public User getUser(String userId){ return (User)getSqlSession().selectOne ("org.mybatis.spring.sample.mapper.UserMapper.getUser",userId); } }
通常MapperFactoryBean是這個類的首選,因為它不需要額外的代碼。但是,如果你需要在DAO中做其它非MyBatis的工作或需要具體的類,那么這個類就是很有用了。SqlSessionDaoSupport需要一個sqlSessionFactory或sqlSessionTemplate屬性來設(shè)置。這些被明確地設(shè)置或由Spring來自動裝配。如果兩者都被設(shè)置了,那么sqlSessionFactory是被忽略的。
假設(shè)類UserMapperImpl是SqlSessionDaoSupport的子類,它可以在Spring中進(jìn)行如下的配置:
<bean id="userMapper" class="org.mybatis.spring.sample.mapper.UserMapperImpl"> <property name="sqlSessionFactory" ref="sqlSessionFactory"/> </bean>
相關(guān)文章
Intellij IDEA導(dǎo)入eclipse web項目的操作步驟詳解
Eclipse當(dāng)中的web項目都會有這兩個文件,但是idea當(dāng)中應(yīng)該是沒有的,所以導(dǎo)入會出現(xiàn)兼容問題,但是本篇文章會教大家如何導(dǎo)入,并且導(dǎo)入過后還能使用tomcat運行,需要的朋友可以參考下2023-08-08SpringBoot整合Elasticsearch游標(biāo)查詢的示例代碼(scroll)
這篇文章主要介紹了SpringBoot整合Elasticsearch游標(biāo)查詢(scroll),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10spring?boot?Mybatis?攔截器實現(xiàn)拼接sql和修改的代碼詳解
這篇文章主要介紹了spring?boot?Mybatis?攔截器實現(xiàn)拼接sql和修改,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05詳解如何把Java中if-else代碼重構(gòu)成高質(zhì)量代碼
這篇文章主要介紹了詳解如何把Java中if-else代碼重構(gòu)成高質(zhì)量代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11