iBatis使用经验总结

1、基于Spring AOP的iBatis的事务控制

(1)数据源的配置,没什么大不了的,所有的都一样。

    <!-- === DATASOURCE === -->
    <bean id="ds" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
        <property name="url" value="jdbc:oracle:thin:@localhost:1521:SONG"/>
        <property name="username" value="EMDP_ADMIN"/>
        <property name="password" value="123456"/>
    </bean>

 

(2)smc 即 SqlMapClient 的配置,这里使用的是Spring提供的SqlMapClientFactoryBean,以使用延迟加载等特性。

    <bean id="smc" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
        <property name="dataSource" ref="ds" />
        <property name="configLocation" value="classpath:sqlMap.xml" />
    </bean>

(3)事务管理器的配置,这里根据我们配置的JDBC的数据源,直接配置一个JDBC的事务管理器即可。

    <bean id="jdbcTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="ds" />
    </bean>

(4)然后只要配置好AOP就可以了。

    <!-- TRANSACTION ADVICE -->
    <tx:advice id="jdbcTransactionAdvice" transaction-manager="jdbcTransactionManager">
        <tx:attributes>
            <tx:method name="save*" rollback-for="Throwable"/>
            <tx:method name="update*" rollback-for="Throwable"/>
            <tx:method name="delete*" rollback-for="Throwable"/>
            <tx:method name="insert*" rollback-for="Throwable"/>
            <tx:method name="find*" read-only="false"/>
            <tx:method name="query*" read-only="false"/>
            <tx:method name="load*" read-only="false"/>
            <tx:method name="get*" read-only="false"/>
        </tx:attributes>
    </tx:advice>
   
    <aop:config>
        <aop:pointcut id="serviceOperation" expression="execution(* *..I*Service.*(..))"/>
        <aop:advisor advice-ref="jdbcTransactionAdvice" pointcut-ref="serviceOperation"/>
    </aop:config>

这样就让所有的I*Service的实现类都有了声明的事务控制了,代码里面就无需再去考虑开始一个事务、提交一个事务等问题了(前提是使用了配置的数据源对象)。

 

2、IBatis参数传递

IBatis里需要手工写Sql语句模板,这样就需要向模板传递参数。凭现在的经验,只要有3中方式。

(1)直接的基本数据类型,如int ,String等,通过parameterClass设置,在语句模板里使用#value#占位符可以获取。

(2)Pojo对象,通过parameterClass设置,在语句模板里使用#propertyName#的方式获取。

(3)map对象,通过parameterClass设置,在语句模板里使用#keyName#的方式获取。

(4)预先定义的parameterMap,通过parameterMap设置,特别注意,在语句末班里是使用“?”作为占位符的,parameterMap里定义的顺序及占位符的顺序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值