Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/346.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Spring事务注释不工作_Java_Spring_Transactions_Spring Transactions - Fatal编程技术网

Java Spring事务注释不工作

Java Spring事务注释不工作,java,spring,transactions,spring-transactions,Java,Spring,Transactions,Spring Transactions,我将Spring3.2.4与JavaFX一起使用,并希望实现一个方法,其中操作将在事务中执行。我在控制器中的代码如下所示: @Transactional(rollbackFor = { ServiceException.class, ValidationException.class }) public void registerVolunteer(User user, Volunteer volunteer) throws Service

我将Spring3.2.4与JavaFX一起使用,并希望实现一个方法,其中操作将在事务中执行。我在控制器中的代码如下所示:

@Transactional(rollbackFor = { ServiceException.class,
            ValidationException.class })
    public void registerVolunteer(User user, Volunteer volunteer)
            throws ServiceException, ValidationException {
        User ret = userService.create(user);
        volunteer.setUser(ret);
        volunteerService.untransactedCreate(volunteer);
    }
和我的应用程序上下文:

<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>

    <!-- Transaction Manager -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

该方法存在。删除注释,或者将方法从
public
更改为
private
,或者从配置中删除bean,程序运行,但是
@Transactional
-注释根本不起作用。删除代理目标class=“true”会导致另一个错误。

如果您谈论的是
@Transactional
,则它用于回滚当前事务

这主要用于制作测试用例,让我向您展示:

RunWith(SpringJUnit4ClassRunner.class)
@WebAppConfiguration
@ContextConfiguration("file:src/main/webapp/WEB-INF/dispatcher-servlet.xml")
@TransactionConfiguration(transactionManager = "txManager",defaultRollback = true)
@Transactional
public class AddVendorProcessorTest{

   // Your code
}
现在,在
@TransactionConfiguration
中,从这里获取一个XML文件
transactionManager

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="org.postgresql.Driver"/>
    <property name="url" value="jdbc:postgresql://localhost:5432/db"/>
    <property name="username" value="postgres"/>
    <property name="password" value="pwd"/>
    <property name="validationQuery" value="SELECT 1"/>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="packagesToScan" value="com.domain"/>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.format_sql">true</prop>
            <prop key="hibernate.generate_statistics">true</prop>
        </props>
    </property>
</bean>

<!-- Transaction Manager -->
<bean id="txManager"
      class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

<tx:annotation-driven transaction-manager="txManager" />

org.hibernate.dialogue.PostgreSqlDialogue
真的
真的
真的
它将自动获取
txManager
bean


如果有任何查询发帖给我。

您的错误消息与事务性注释无关。您可能会在stacktrace中注意到,您根本没有对Spring应用程序上下文的引用。仅当您的服务未实现接口时,才需要使用CGLIB代理目标类。您的例外是JavaFX找不到控制器方法。这个控制器是用
@controller
注释的吗?您的SpringXML中有
吗?我将该方法移动到一个单独的服务类中,这解决了这个问题。我没有这两个,因为我正在用JavaFX开发一个本地应用程序,而不是使用MVC。错误消息与注释无关,但将方法从public更改为private删除了错误消息,这对我来说似乎很奇怪,但我对Spring的细节了解不多,所以…再次强调,我没有使用MVC。控制器在我的例子中是指JavaFX控制器。
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="org.postgresql.Driver"/>
    <property name="url" value="jdbc:postgresql://localhost:5432/db"/>
    <property name="username" value="postgres"/>
    <property name="password" value="pwd"/>
    <property name="validationQuery" value="SELECT 1"/>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="packagesToScan" value="com.domain"/>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.format_sql">true</prop>
            <prop key="hibernate.generate_statistics">true</prop>
        </props>
    </property>
</bean>

<!-- Transaction Manager -->
<bean id="txManager"
      class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

<tx:annotation-driven transaction-manager="txManager" />