這篇文章主要介紹iBaits中SqlMapClientTemplate怎么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
10年積累的成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先建設(shè)網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有扶溝免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
Apache iBatis(現(xiàn)已遷至Google Code下發(fā)展,更名為MyBatis)是當(dāng)前IT項(xiàng)目中使用很廣泛的一個(gè)半自動(dòng)ORM框架,區(qū)別于Hibernate之類的全自動(dòng)框架,iBatis對(duì)數(shù)據(jù)庫(kù)的操作擁有更加靈活的控制,對(duì)于那些經(jīng)常需要調(diào)用本地?cái)?shù)據(jù)庫(kù)函數(shù)自定義SQL語(yǔ)句,或是喜歡自己優(yōu)化SQL執(zhí)行效率的開(kāi)發(fā)者來(lái)說(shuō),iBatis是一個(gè)非常不錯(cuò)的選擇。而得到廣泛應(yīng)用的開(kāi)源企業(yè)架構(gòu)SpringFramework,也很好的將其進(jìn)行了集成,使得iBatis在 SpringFramework中的使用更加便利、快捷。開(kāi)發(fā)者所要做的就是繼承SpringFramework中提供的 SqlMapClientDaoSupport類即可。下面,我將自己的使用經(jīng)驗(yàn)與大家分享一下:
1、SqlMapClientFactoryBean 的裝配
SqlMapClientFactoryBean是SqlMapClientTemplate使用的基礎(chǔ),如果在
SpringFramework應(yīng)用中沒(méi)有裝配SqlMapClientFactoryBean,那么SqlMapClientTemplate將不可用,報(bào)空指針錯(cuò)誤。
bean>
2、繼承使用SqlMapClientDaoSupport類
聲明Java類:
...... import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport; ...... public class ReportDAOImpl extends SqlMapClientDaoSupport { ...... } SpringFramework配置文件中裝配Java類:"reportDao" class="com.test.dao.ReportDAOImpl"> "sqlMapClient" ref="sqlMapClient"/>
SpringFramework配置文件中裝配Java類:
3、使用SqlMapClientTemplate查詢
Java代碼:
當(dāng)執(zhí)行沒(méi)有參數(shù)的查詢時(shí):
List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTest");
"TestSpace"為iBatis SqlMap文件的命名空間;"qryTest"為iBatis SqlMap的查詢方法id
當(dāng)按照主鍵獲取某條記錄信息時(shí):
Long id = new Long("2"); Object resultObj = getSqlMapClientTemplate().queryForObject("TestSpace.getTest", id);
當(dāng)按照某些條件查詢時(shí):
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)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!