jdbcTemplate和hibernateTemplate之一

jdbcTemplate原理:

我们都知道在使用jdbc连接数据库的时候:
conn=dataSource.getConnection();
stmt=con.createStatement();
stmt.executeUpdate(...);
这就会直接保存到数据库,因为默认下conn.setAutoCommit(true),
如果我们要手动则,conn.setAutoCommit(false)就是了.

spring jdbcTemplate中,我们一般直接向我们的dao层注入jdbcTemplate,再运行jdbcTemplate.update()也会把数据保存到数据库中去.因为他底层使用的是jdbc所以默认下事务是自动保存的.

如果dao一个方法中有两名,jdbcTemaplte.update(1),jdbcTemplate.update(2),1和2没有关系,如果1保存成功,2失败则1还是成功,因为1运行所会自己保存.我们一般要的是1,2同时成功,同时失败.

我们来看一下,spring中怎么实现,办法我有两个,一在代码是写如:
配置事务管理
<beand id="trnasactionManager" class="org.springframework.jdbc.dataSource.DataSourceTranactionManager">
<property name="dataSource"><reflocal="dataSource" /></property>
</bean>

我们在我们的dao注入dataSource和transactionManager就是了

假如insert()方法就是我们用来保存数据的
public void insert(){
TransactionTemplate tt=new TransactionTemplate(transactionManager);

tt.execute(new transactionCallback(){
public object doIntransactioan(TransactionStatus status){
JdbcTemplate jt=new JdbcTemplate(dataSource);
jt.update(1);
jt.update(2);
return null;
} });//引入springGuide书中的例子
}
那么事务是什么时候开启的呢?
我们可以查看transactionTemplate源代码:看到execute方法中有

public Object execute(TransactionCallback action) throws TransactionException {
if (this.transactionManager instanceof CallbackPreferringPlatformTransactionManager) {
return ((CallbackPreferringPlatformTransactionManager) this.transactionManager).execute(this, action);
}
else {
TransactionStatus status = this.transactionManager.getTransaction(this);
Object result = null;
try {
result = action.doInTransaction(status);
}
catch (RuntimeException ex) {
// Transactional code threw application exception -> rollback
rollbackOnException(status, ex);
throw ex;
}
catch (Error err) {
// Transactional code threw error -> rollback
rollbackOnException(status, err);
throw err;
}
this.transactionManager.commit(status);
return result;
}
}

看到TransactionStatus status = this.transactionManager.getTransaction(this);
我们再去查看transactionManager,我们看dataSourceTransactionManager,发现,他继承 AbstractPlatformTransactionManager,而aptm它的getTransaction这里配置一些事务,调用了doBegin(transaction, definition);这就开启事务,
当TransactionTemplate中execute最后执行的是this.transactionManager.commit(status);事务提交.

办法二,配置参数
配置
<bean id="userDaoProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
注入 trnsactionManger target=你的Dao
transactionAttributes
<prop key="insert*">propagation_required</prop>
</bean>//我这是简单具体的配置没有写,引入springGuide书中

而我们的dao只在注入dataSource就是了,
public void insert(){
JdbcTempalte jt=new JdbcTemplate(dataSource);
jt.update(1);
jt.update(2);
}

其实两种方法是一样的.只不过,在配置用户中被除数trndactionProxyFactoryBean拦截了,但具体实现是和一一样的.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值