溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

iBaits中SqlMapClientTemplate怎么用

發(fā)布時間:2021-11-03 17:58:04 來源:億速云 閱讀:157 作者:小新 欄目:編程語言

這篇文章主要介紹iBaits中SqlMapClientTemplate怎么用,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

Apache iBatis(現(xiàn)已遷至Google Code下發(fā)展,更名為MyBatis)是當(dāng)前IT項(xiàng)目中使用很廣泛的一個半自動ORM框架,區(qū)別于Hibernate之類的全自動框架,iBatis對數(shù)據(jù)庫的操作擁有更加靈活的控制,對于那些經(jīng)常需要調(diào)用本地?cái)?shù)據(jù)庫函數(shù)自定義SQL語句,或是喜歡自己優(yōu)化SQL執(zhí)行效率的開發(fā)者來說,iBatis是一個非常不錯的選擇。而得到廣泛應(yīng)用的開源企業(yè)架構(gòu)SpringFramework,也很好的將其進(jìn)行了集成,使得iBatis在 SpringFramework中的使用更加便利、快捷。開發(fā)者所要做的就是繼承SpringFramework中提供的 SqlMapClientDaoSupport類即可。下面,我將自己的使用經(jīng)驗(yàn)與大家分享一下:

1、SqlMapClientFactoryBean 的裝配

SqlMapClientFactoryBean是SqlMapClientTemplate使用的基礎(chǔ),如果在

SpringFramework應(yīng)用中沒有裝配SqlMapClientFactoryBean,那么SqlMapClientTemplate將不可用,報(bào)空指針錯誤。

<bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">         <property name="configLocation" value="/WEB-INF/sqlmap-config.xml"/>          <property name="dataSource" ref="dataSource"/>          <property name="lobHandler" ref="oracleLobHandler"/>      bean>

2、繼承使用SqlMapClientDaoSupport類

聲明Java類:

   ......         import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;         ......         public class ReportDAOImpl extends SqlMapClientDaoSupport {             ......         }         SpringFramework配置文件中裝配Java類:         <BEAN ID=< span>"reportDao" class="com.test.dao.ReportDAOImpl">             <PROPERTY NAME=< span>"sqlMapClient" ref="sqlMapClient"/>

SpringFramework配置文件中裝配Java類:

3、使用SqlMapClientTemplate查詢

Java代碼:

當(dāng)執(zhí)行沒有參數(shù)的查詢時:

List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTest");

"TestSpace"為iBatis SqlMap文件的命名空間;"qryTest"為iBatis SqlMap的查詢方法id

當(dāng)按照主鍵獲取某條記錄信息時:

Long id = new Long("2");        Object resultObj = getSqlMapClientTemplate().queryForObject("TestSpace.getTest", id);

當(dāng)按照某些條件查詢時:

ObjectA objA = new ObjectA();         objA.setParam1("test1");         objA.setParam2("test2");         ......         List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTestByParam", objA);

如果需要取4~40條數(shù)據(jù):

List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTestByParam", objA, 4, 40);

也可以返回Map

Map result = getSqlMapClientTemplate().queryForMap("TestSpace.qryTestByParam", objA, "MapKey");

4、使用SqlMapClientTemplate添加數(shù)據(jù)

Java代碼:

ObjectA objA = new ObjectA();
objA.setParam1("test1");        objA.setParam2("test2");        ......        getSqlMapClientTemplate().insert("TestSpace.insertTest", objA);

5、使用SqlMapClientTemplate更新數(shù)據(jù)

Java代碼:

ObjectA objA = new ObjectA();         objA.setParam1("test1");         objA.setParam2("test2");         ......         getSqlMapClientTemplate().update("TestSpace.updateTest", objA);

更新前20條記錄:

Java代碼

getSqlMapClientTemplate().update("TestSpace.updateTest", objA, 20);

6、使用SqlMapClientTemplate刪除數(shù)據(jù)

Java代碼:

Long id = new Long("2");        getSqlMapClientTemplate().delete("TestSpace.deleteTest", id);

以上是“iBaits中SqlMapClientTemplate怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI