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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

详解iBaits中SqlMapClientTemplate的使用

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

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

1、SqlMapClientFactoryBean 的裝配

SqlMapClientFactoryBean是SqlMapClientTemplate使用的基礎,如果在

SpringFramework應用中沒有裝配SqlMapClientFactoryBean,那么SqlMapClientTemplate將不可用,報空指針錯誤。

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

    當執行沒有參數的查詢時:

    Java代碼

    ?

    ?

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

    當按照主鍵獲取某條記錄信息時:

    Java代碼

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

    當按照某些條件查詢時:

    Java代碼

  • ObjectA objA =?new?ObjectA();
  • objA.setParam1("test1");
  • objA.setParam2("test2");
  • ......
  • List result = getSqlMapClientTemplate().queryForList("TestSpace.qryTestByParam", objA);
  • 如果需要取4~40條數據:

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

    也可以返回Map

    Java代碼

    ?

    ?

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

    4、使用SqlMapClientTemplate添加數據

    Java代碼:

    ?

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

    ?

    ?

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

    5、使用SqlMapClientTemplate更新數據

    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刪除數據

    Java代碼:

    Java代碼

    ?

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

    總結

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

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