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拦截了,但具体实现是和一一样的.
我们都知道在使用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拦截了,但具体实现是和一一样的.