读书人

JdbcTemplate与事宜

发布时间: 2012-08-27 21:21:57 作者: rapoo

JdbcTemplate与事务

为了实现数据操作的原子性,我们需要在程序中引入事务逻辑,在JdbcTemplate中引入事务机制,在Spring中有两种方式:
1. 代码控制的事务管理
2. 参数化配置的事务管理
下面就这两种方式进行介绍。

代码控制的事务管理
首先,进行以下配置,假设配置文件为(Application-Context.xml):
<beans>
<bean id="dataSource"
/>
</property>
</bean>
<bean id="userDAO" />
</property>
<property name="transactionManager">
<ref local="transactionManager" />
</property>
</bean>
</beans>
配置中包含了三个节点:
? dataSource
这里我们采用了apache dhcp组件提供的DataSource实现,并为其配置了
JDBC驱动、数据库URL、用户名和密码等参数。
? transactionManager
针对JDBC DataSource类型的数据源,我们选用了
DataSourceTransactionManager
作为事务管理组件。
如果需要使用基于容器的数据源(JNDI),我们可以采用如下配置:
<bean id="dataSource"
/>
</property>
<property name="target">
<ref local="userDAO" />
</property>
<property name="transactionAttributes">
<props>
<prop key="insert*">PROPAGATION_REQUIRED</prop>
<prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<bean id="userDAO" />
</property>
</bean>
上面的配置中,UserDAOProxy节点配置了一个针对userDAO bean的事务代理(由target属性指定)。
通过transactionAttributes属性,我们指定了事务的管理策略,即对所有以insert开头的方法进行事务管理,如果被管理方法抛出异常,则自动回滚方法中的事务,如果成功执行,则在方法完成之后进行事务提交。另一方面,对于其他方法(通过通配符*表示),则进行只读事务管理,以获得更好的性能。
与之对应,UserDAO.insertUser的代码修改如下:
public void insertUser(RegisterInfo regInfo) {
JdbcTemplate jt = new JdbcTemplate(executeTestSource());
jt.update("insert into users (username) values ('xiaxin');");
jt.update("insert into users (id,username) values (2,'erica');");
}

测试代码修改如下:
InputStream is = new FileInputStream("Application-Context.xml");
XmlBeanFactory factory = new XmlBeanFactory(is);
//注意这里须通过代理Bean"userDAOProxy"获得引用,而不是直接getBean(“userDAO”)
//此外这里还存在一个有关强制转型的潜在问题,请参见Hibernate in Spring一节后
//关于强制转型的补充描述。
UserDAO userDAO = (UserDAO) factory.getBean("userDAOProxy");
userDAO.insertUser();
可以看到,insertUser变得非常简洁。数据逻辑清晰可见,对比前面代码控制的事务管理,以及传统的JDBC操作,相信大家会有一些霍然开朗的感觉。
细心的读者会说,这只不过将代码转移到了配置文件,并没有减少太多的工作量。这点区别也许并不重要,从应用维护的角度而言,配置化的事务管理显然更具优势。何况,实际开发中,如果前期设计细致,方法的事务特性确定之后一般不会发生大的变动,之后频繁的维护过程中,我们只需面对代码中的数据逻辑即可。

上面我们结合JdbcTemplate介绍了Spring中的模板操作以及事务管理机制。Spring作为一个开放式的应用开发平台。同时也针对其他组件提供了良好的支持。在持久层,Spring提供面向了Hibernate、ibatis和JDO的模板实现,同样,这些实现也为我们的开发提供了强有力的支持。

?

读书人网 >其他数据库

热点推荐