这次在江西电信企业管理数据视图项目中,使用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、暂时只有这么多需要注意的,随着实践的深入肯定还有很多让人迷惑的地方。