现在的位置: 首页 > 综合 > 正文

ibatis学习–使用经验总结

2013年10月14日 ⁄ 综合 ⁄ 共 2282字 ⁄ 字号 评论关闭

   这次在江西电信企业管理数据视图项目中,使用iBatis作为持久层框架,直接写sql语句,与DBMS有更亲密的接触,找回了那种“控制感”的爽快啊!以前一直用Hibernate,比较下来,似乎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里定义的顺序及占位符的顺序。

 

3、暂时只有这么多需要注意的,随着实践的深入肯定还有很多让人迷惑的地方。

抱歉!评论已关闭.