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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

详解iBaits中SqlMapClientTemplate的使用

發(fā)布時(shí)間:2024/4/14 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 详解iBaits中SqlMapClientTemplate的使用 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Apache iBatis(現(xiàn)已遷至Google Code下發(fā)展,更名為MyBatis)是當(dāng)前IT項(xiàng)目中使用很廣泛的一個(gè)半自動(dòng)ORM框架,區(qū)別于Hibernate之類的全自動(dòng)框架,iBatis對數(shù)據(jù)庫的操作擁有更加靈活的控制,對于那些經(jīng)常需要調(diào)用本地?cái)?shù)據(jù)庫函數(shù)自定義SQL語句,或是喜歡自己優(yōu)化SQL執(zhí)行效率的開發(fā)者來說,iBatis是一個(gè)非常不錯(cuò)的選擇。而得到廣泛應(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)空指針錯(cuò)誤。

Java代碼

  • <beanid="sqlMapClient"class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
  • <propertyname="configLocation"value="/WEB-INF/sqlmap-config.xml"/>
  • <propertyname="dataSource"ref="dataSource"/>
  • <propertyname="lobHandler"ref="oracleLobHandler"/>
  • bean>
  • 2、繼承使用SqlMapClientDaoSupport類

    聲明Java類:

    Java代碼

    ?

  • ......
  • import?org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;
  • ......
  • publicclass?ReportDAOImpl?extends?SqlMapClientDaoSupport {
  • ......
  • }
  • SpringFramework配置文件中裝配Java類:
  • "reportDao"class="com.test.dao.ReportDAOImpl">
  • "sqlMapClient"?ref="sqlMapClient"/>
  • ?

    SpringFramework配置文件中裝配Java類:

    3、使用SqlMapClientTemplate查詢

    Java代碼:

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

    Java代碼

    ?

    ?

  • List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTest");
  • "TestSpace"為iBatis SqlMap文件的命名空間;"qryTest"為iBatis SqlMap的查詢方法id

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

    Java代碼

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

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

    Java代碼

  • 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

    Java代碼

    ?

    ?

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

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

    Java代碼:

    ?

  • ObjectA objA =?new?ObjectA();
  • Java代碼

    ?

    ?

  • objA.setParam1("test1");
  • objA.setParam2("test2");
  • ......
  • getSqlMapClientTemplate().insert("TestSpace.insertTest", objA);
  • ?

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

    Java代碼:

    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代碼:

    Java代碼

    ?

  • Long id =?new?Long("2");
  • getSqlMapClientTemplate().delete("TestSpace.deleteTest", id);
  • 轉(zhuǎn)載于:https://www.cnblogs.com/mqws/p/6283012.html

    總結(jié)

    以上是生活随笔為你收集整理的详解iBaits中SqlMapClientTemplate的使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。