Spring通过DAO模式,提供了对iBATIS的良好支持。SqlMapClient对象是iBATIS中的主要对象,我们可以通过配置让spring来管理SqlMapClient对象的创建,继而整合iBatis和Spring。

与hibernate类似,Spring 提供了SqlMapClientDaoSupport对象,我们的DAO可以继承这个类,通过它所提供的SqlMapClientTemplate对象来操纵数据库。看起来这些概念都与hibernate类似。
通过SqlMapClientTemplate来操纵数据库的CRUD是没有问题的,这里面关键的问题是事务处理。Spring提供了强大的声明式事务处理的功能,我们已经清楚hibernate中如何配置声明式的事务,那么在iBATIS中如何获得声明式事务的能力呢?我们又怎样整合iBatis和Spring呢?
第一,我们需要了解的是spring通过AOP来拦截方法的调用,从而在这些方法上面添加声明式事务处理的能力。典型配置如下:applicationContext-common.xml
  1. <!-- 配置事务特性 -->
  2. <tx:advice id="txAdvice" transaction-manager="事务管理器名称">
  3. <tx:attributes>
  4. <tx:method name="add*" propagation="REQUIRED"/>
  5. <tx:method name="del*" propagation="REQUIRED"/>
  6. <tx:method name="update*" propagation="REQUIRED"/>
  7. <tx:method name="*" read-only="true"/>
  8. </tx:attributes>
  9. </tx:advice>
  10. <!-- 配置哪些类的方法需要进行事务管理 -->
  11. <aop:config>
  12. <aop:pointcut id="allManagerMethod" expression="execution(* com.ibatis.manager.*.*(..))"/>
  13. <aop:advisor advice-ref="txAdvice" pointcut-ref="allManagerMethod"/>
  14. </aop:config>

这些事务都是声明在业务逻辑层的对象上的。 第二,我们需要一个事务管理器,对事务进行管理,实现整合iBatis和Spring的第二步。

  1. <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  2. <property name="dataSource" ref="dataSource"/>
  3. </bean>
  4. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
  5. <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
  6. <property name="url" value="jdbc:mysql://127.0.0.1/ibatis"/>
  7. <property name="username" value="root"/>
  8. <property name="password" value="mysql"/>
  9. </bean>

此后,我们需要让spring来管理SqlMapClient对象,实现整合iBatis和Spring的第三步

  1. <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
  2. <property name="configLocation"><value>classpath:sqlMapConfig.xml</value></property>
  3. </bean>

我们的sqlMapConfig.xml就可以简写为:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE sqlMapConfig
  3. PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
  4. "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
  5. <sqlMapConfig>
  6. <settings
  7. lazyLoadingEnabled="true"
  8. useStatementNamespaces="true" />
  9. <!-- 使用spring之后,数据源的配置移植到了spring上,所以iBATIS本身的配置可以取消 -->
  10. <sqlMap resource="com/ibatis/dao/impl/ibatis/User.xml"/>
  11. </sqlMapConfig>
  12. User.xml:如下
  13. <?xml version="1.0" encoding="UTF-8" ?>
  14. <!DOCTYPE sqlMap
  15. PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
  16. "http://ibatis.apache.org/dtd/sql-map-2.dtd">
  17. <sqlMap namespace="User">
  18. <!-- Use type aliases to avoid typing the full classname every time. -->
  19. <typeAlias alias="User" type="com.ibatis.User"/>
  20. <!-- Select with no parameters using the result map for Account class. -->
  21. <select id="selectAllUsers" resultClass="User">
  22. select * from t_user
  23. </select>
  24. <select id="selectUser" resultClass="User" parameterClass="int">
  25. select * from t_user where id=#id#
  26. </select>
  27. <insert id="insertUser" parameterClass="User">
  28. insert into t_user values (
  29. null,#username#,#password#
  30. )
  31. </insert>
  32. <update id="updateUser" parameterClass="User">
  33. update t_user set username = #username#,password=#password#
  34. where id=#id#
  35. </update>
  36. <delete id="deleteUser" parameterClass="int">
  37. delete from t_user where id=#id#
  38. </delete>
  39. </sqlMap>

我们的DAO的编写:

  1. package com.iabtis.dao.impl.ibatis;
  2. import java.util.List;
  3. import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;
  4. import com.ibatis.dao.UserDAO;
  5. import com.ibatis.crm.model.User;
  6. public class UserDAOImpl extends SqlMapClientDaoSupport implements UserDAO {
  7. public void select(User user) {
  8. getSqlMapClientTemplate().delete("selectUser ",user.getId());
  9. }
  10. public List findAll() {
  11. return getSqlMapClientTemplate().queryForList("selectAllUsers ");
  12. }
  13. public void delete(User user) {
  14. getSqlMapClientTemplate().delete("deleteUser ",user.getId());
  15. }
  16. public void save(User user) {
  17. getSqlMapClientTemplate().insert("insertUser ",user);
  18. }
  19. public void update(User user) {
  20. getSqlMapClientTemplate().update("updateUser ",user);
  21. }
  22. }

继承SqlMapClientDaoSupport,要求我们注入SqlMapClient对象,因此,需要有如下的DAO配置,这是整合iBatis和Spring的最后一步了

  1. <bean id="userDAO" class="com.ibatils.dao.impl.ibatis.UserDAOImpl">
  2. <property name=”sqlMapClient” ref=”sqlMapClient”/>
  3. </bean>

这就是所有需要注意的问题了,此后就可以在业务逻辑层调用DAO对象了!

转载于:https://www.cnblogs.com/sysmfh5200/archive/2013/05/07/sym5200.html

Spring中的Ibatis之SqlMapClientDaoSupport相关推荐

  1. Spring中的事务管理详解

    在这里主要介绍Spring对事务管理的一些理论知识,实战方面参考上一篇博文: http://www.cnblogs.com/longshiyVip/p/5061547.html 1. 事务简介: 事务 ...

  2. 在Spring中使用JTA事务管理

    在Spring中使用JTA事务管理 Spring 通过AOP技术可以让我们在脱离EJB的情况下享受声明式事务的丰盛大餐,脱离Java EE应用服务器使用声明式事务的道路已经畅通无阻.但是很大部分人都还 ...

  3. spring中@param和mybatis中@param使用区别

    spring中@param /*** 查询指定用户和企业关联有没有配置角色* @param businessId memberId* @return*/int selectRoleCount(@Par ...

  4. spring中事务控制的一组API

    Spring事务控制我们要明确的 第一:JavaEE体系进行分层开发,事务处理位于业务层,Spring提供了分层设计业务层的事务处理解决方案. 第二:spring框架为我们提供了一组事务控制的接口.具 ...

  5. spring事务管理器的作用_【面试必问】Spring中的事务管理详解

    在这里主要介绍Spring对事务管理的一些理论知识,实战方面参考上一篇博文: http://www.cnblogs.com/longshiyVip/p/5061547.html 1. 事务简介: 事务 ...

  6. Spring中的事务控制

    Chapter 1. Spring中的事务控制(Transacion Management with Spring) Table of Contents 1.1. 有关事务(Transaction)的 ...

  7. Spring中的事务控制(Transacion Management with Spring)

    1.1. 有关事务(Transaction)的楔子 1.1.1. 认识事务本身1.1.2. 初识事务家族成员 1.2. 群雄逐鹿下的Java事务管理 1.2.1. Java平台的局部事务支持1.2.2 ...

  8. 在Spring中使用JOTM实现JTA事务管理

    Spring 通过AOP技术可以让我们在脱离EJB的情况下享受声明式事务的丰盛大餐,脱离Java EE应用服务器使用声明式事务的道路已经畅通无阻.但是很大部分人都还认为脱离Java EE应用服务器就无 ...

  9. Spring中进行事务管理的两种方式

    1.Spring中事务管理的API 事务是指逻辑上要么全部成功.要么全部失败的一组操作.例如用户A给用户B转账,则用户A账户余额减少.用户B账户增加这两个操作就是一组事务,必须全部成功或失败撤回操作, ...

最新文章

  1. 【青少年编程】【四级】奇偶之和
  2. select查询中@作用_SQL学习第四关:复杂查询
  3. 解决在thinkphp5.0中用ajax访问后台控制器方法时,返回的数据显示不出来
  4. 分享18道Java基础面试笔试题
  5. [Swift]LeetCode682. 棒球比赛 | Baseball Game
  6. In this way, Wang Xing became Li Xiang’s closest
  7. python21天打卡day7-字典
  8. 继续跟上--“永远不要对一个外行聊你的专业”
  9. 理解分布式和区块链技术
  10. python 四象限图_如何制作四象限气泡图表
  11. python 快乐的数字
  12. LeetCode上的各种股票最大收益
  13. 清除壁垒 大数据推动城市规划质突破
  14. blastall参数详解
  15. Ansible-template模块使用(jinjia2模板)
  16. 一个Windows进程管理的小工具源码
  17. mysql里面除号写法_MySQL常见函数 - osc_mgt0rm0m的个人空间 - OSCHINA - 中文开源技术交流社区...
  18. Jetson嵌入式系列模型部署-3
  19. 微信小程序收款手续费_小程序微信支付收款流程
  20. Codeforces Round #601 (Div. 2)B. Fridge Lockers

热门文章

  1. python线程创建对象_Python线程下thread对象的用法介绍(附实例)
  2. 关于cookie domain中的点前缀
  3. XGboost 实战糖尿病预测
  4. [译]GC专家系列1:理解Java垃圾回收
  5. 1.6-1.7配置IP1.8网络问题排查
  6. Chatbot大牛推荐:AI、机器学习、深度学习必看9大入门视频
  7. 理解水平扩展和垂直扩展
  8. netty5.0通过LineBasedFrameDecoder和StringDecoder解决粘包
  9. mybatis 3.2.2_环境搭建
  10. 转贴:Hyper-V的几款免费管理工具