Spring JDBC事务管理器



我尝试在Spring中使用JDBC编写事务管理器。

我的app-servlet.xml

<!-- JDBC Config -->
<bean   id="dataSource" 
        class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close" 
        p:driverClassName="${jdbc.driverClassName}"
        p:url="${jdbc.databaseurl}" 
        p:username="${jdbc.username}" 
        p:password="${jdbc.password}" />
<!-- dataSource TransactionManager -->
<bean id="transactionManager"
    class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource" />
</bean>
<bean id="UserDAOImpl" class="com.project.dao.impl.UserDAOImpl">
    <property name="transactionManager" ref="transactionManager"/>
</bean>

我的UserDAOImpl.java

public class UserDAOImpl implements UserDAO {
//transaction manager
private DataSourceTransactionManager transactionManager;
private JdbcTemplate jdbcTemplate;
public UserDAOImpl() {
    super();
    DataSource dataSource = transactionManager.getDataSource();
    jdbcTemplate = new JdbcTemplate(dataSource);
}
public void setTransactionManager(DataSourceTransactionManager transactionManager)    {
    this.transactionManager = transactionManager;
}
....
}

即使我的应用servlet中有transactionManager Bean,UserDAOImpl也不会安装,因为transactionManagernull。也许我错过了一些要点,但却找不出问题所在。

您应该为事务管理器使用构造函数注入。Spring将在注入transactionManager属性之前调用构造函数。

 public UserDAOImpl() 
 {
    /* Transaction Manager NOT set yet */
    DataSource dataSource = transactionManager.getDataSource();
 }

将其更改为使用构造函数注入

 public UserDAOImpl(TransactionManager transactionManager) ...

然后配置

 <bean id="UserDAOImpl" class="com.project.dao.impl.UserDAOImpl">
   <constructor-arg ref="transactionManager"/>
 </bean>

如果您使用带有注释的spring,这应该可以使用

@Repository
public class UserDAOImpl implements UserDAO{
@Autowired
private DataSourceTransactionManager transactionManager;
private JdbcTemplate jdbcTemplate;
@Autowired
public void setDataSource(DataSource dataSource) {
    this.jdbcTemplate = new JdbcTemplate(dataSource);
}

你可以在配置中取消这一行

<bean id="UserDAOImpl" class="com.project.dao.impl.UserDAOImpl">
<property name="transactionManager" ref="transactionManager"/>
</bean>

而是进行组件扫描:

<!-- Scans within the base package of the application for @Components to configure as beans -->
<context:component-scan base-package="${your package}" />

您可以在文档中参考更多关于这方面的信息。如果您不使用注释,请将给定链接的URL中的发布版本更改为您正在使用的版本。这有足够多的例子可以在没有注释的情况下进行同样的操作。

您是否有属性文件或其他初始化这些变量的方式

p:driverClassName="${jdbc.driverClassName}"
        p:url="${jdbc.databaseurl}" 
        p:username="${jdbc.username}" 
        p:password="${jdbc.password}"

这些是占位符,需要值,例如在这个链接中

有一个名为jdbc.properties的属性文件,它定义了驱动程序类名等的数据。

以下是示例的示例源代码

您还可以修改获取jdbcTemplate:

public void setTransactionManager(DataSourceTransactionManager transactionManager)    {
  this.transactionManager = transactionManager;
  DataSource dataSource = transactionManager.getDataSource();
  jdbcTemplate = new JdbcTemplate(dataSource);
} 

相关内容

  • 没有找到相关文章

最新更新