- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Spring 框架提供了两种编程事务管理的方法:
TransactionTemplate
.PlatformTransactionManager
直接执行。JdbcTemplate
这里。据我了解
JdbcTemplate
还在内部管理事务,这也是在程序中完成的。
TransactionTemplate
之间的基本区别是什么?和
JdbcTemplate
?
最佳答案
JdbcTemplate
不是事务管理器。它只是 native JDBC 操作的辅助类:
This is the central class in the JDBC core package. It simplifies the use of JDBC and helps to avoid common errors. It executes core JDBC workflow, leaving application code to provide SQL and extract results. This class executes SQL queries or updates, initiating iteration over ResultSets and catching JDBC exceptions and translating them to the generic, more informative exception hierarchy defined in the org.springframework.dao package.
TransactionTemplate
顺便说一句也不是事务管理器,它是一个
Template class that simplifies programmatic transaction demarcation and transaction exception handling.
PlatformTransactionManager
(以及
AbstractPlatformTransactionManager
的其他子类)
是事务管理器 ,正如其中
TransactionTemplate
,如果您想以编程方式实现它而不是声明性事务处理,则将使用它。 (参见
this 博客,虽然已经过时,但您会看到声明式和手动式的区别)
JdbcTemplate
:
private DataSource dataSource;
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
}
public void insert(Customer customer){
String sql = "INSERT INTO CUSTOMER " +
"(CUST_ID, NAME, AGE) VALUES (?, ?, ?)";
Connection conn = null;
try {
conn = dataSource.getConnection();
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, customer.getCustId());
ps.setString(2, customer.getName());
ps.setInt(3, customer.getAge());
ps.executeUpdate();
ps.close();
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {}
}
}
}
JdbcTemplate
:
private DataSource dataSource;
private JdbcTemplate jdbcTemplate;
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
}
public void insert(Customer customer){
String sql = "INSERT INTO CUSTOMER " +
"(CUST_ID, NAME, AGE) VALUES (?, ?, ?)";
jdbcTemplate = new JdbcTemplate(dataSource);
jdbcTemplate.update(sql, new Object[] { customer.getCustId(),
customer.getName(),customer.getAge()
});
}
关于spring - TransactionTemplate 与 JdbcTemplate,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6558871/
Spring 框架提供了两种编程事务管理的方法: 使用 TransactionTemplate . 使用 PlatformTransactionManager直接执行。 以上描述在这里:http://
由于并发访问,我遇到了数据结构损坏的问题。我试图排除可能的原因,但我不确定 Spring TransactionTemplate 是如何工作的。 有多个线程将独立列表传递给 CallbackHandl
我必须在处理变量之前更新数据库中变量的状态,以确保只有一个线程处理它。 为此,我正在使用 spring 的 transactionTemplate所以我的疑问是:如果我有类似的东西: Tran
我想知道 TransactionTemplate 的 setPropagationBehavior 究竟做了什么。谁向谁传播什么?我看到它有很好的文档记录,但我不了解此 PropagationBeha
我的 DAO 中的以下代码运行良好。 public void insert(final Person person) { transactionTemplate.execute(new Tra
我正在尝试使用 transactionTemplate 来管理我的交易。代码可能如下: private Boolean isCleanSuccess(){ return transaction
我正在使用 DB 连接池的自定义数据源(apache DBCP2 和 MySQL 数据库版本 8)进行连接池,并尝试使用 Spring TransactionTemplate 删除 DB 对象(超过
我的服务中有几个@Transactional私有(private)方法,由于不推荐使用@Transactional而不是私有(private)方法,所以我使用org.springframework.t
我的 Spring 应用程序中有一个特定的流程调用。 我有一个存储库,并且我在第一次调用时调用了 sell() 方法。 @Service @Transactional public class Ser
我目前正在处理的代码中有一个被许多线程使用的单例,除了 TransactionTemplate 和 SimpleJdbcTemplate 的两个字段外没有任何状态,这两个字段在单例函数中用于访问数据库
我不太确定如何提出这个问题,所以尽管告诉我我的想法完全错误。 我想使用 JdbcTemplate 和 TransactionTemplate。我首先将我的连接池初始化为数据源,然后创建一个事务管理器作
有人可以解释为什么第一个单元测试类工作而第二个测试类失败并出现锁定等待超时错误? 第一个类: public class Test1 extends AbstractTransactionalJUnit
我正在尝试创建 TransactionTemplate 的模拟 var tTemplate = MockRepository.GenerateMock(); var tDelegate = MockR
我是一名优秀的程序员,十分优秀!