2015-08-17 3 views
0

Без @Transactional, если бы мои работы веб-приложений, но когда он называет удалить, я получаю следующее исключение:JPA спящий режим @Transactional конфигурации

обработка запроса не удалось; вложенное исключение javax.persistence.TransactionRequiredException: Нет транзакционных EntityManager доступны

Так что я хотел бы сделать это транзакционный, но если добавить @Transactional к классу или методу, когда я запустить приложение я получаю :

Нет квалификационная рожкового типа [net.tirasa.jpaaddressbook.JpaEntryDAO] найденного зависимостей: ожидается, по крайней мере, 1 боб, который квалифицируется как autowire кандидата на эту зависимость.

Мои JpaEntryDAO является:

@Repository 
public class JpaEntryDAO implements EntryDAO { 

@PersistenceContext 
@Autowired 
private EntityManager entityManager; 


@Override 
@Transactional // <<<<<<------- add or remove it 
public void remove(int id) { 
    Entry entry = new Entry(); 
    entityManager.remove(id); 
} 
//[...] 

Класс контроллера:

@Controller 

общественного класса AddressBookController {

@Autowired 
private JpaEntryDAO dao; 

@RequestMapping(value = { "/", "/index" }) 
public void home() { 
} 
[...] 

И файл applicationContext.xml является:

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 
     xmlns:tx="http://www.springframework.org/schema/tx" xmlns:p="http://www.springframework.org/schema/p" 
     xsi:schemaLocation="http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context-3.0.xsd 
    http://www.springframework.org/schema/tx 
    http://www.springframework.org/schema/tx/spring-tx.xsd"> 

    <!-- enable the configuration of transactional behavior based on annotations --> 
    <tx:annotation-driven transaction-manager="transactionManager" />  
    <context:component-scan base-package="net.tirasa.jpaaddressbook/"/> 
    <context:annotation-config /> 

    <bean class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor" /> 

    <!--<bean id="dao" class="net.tirasa.jpaaddressbook.JpaEntryDAO"/>--> 

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
    <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 
    <property name="url" value="jdbc:mysql://localhost/Rubrica" /> 
    <property name="username" value="matt3o" /> 
    <property name="password" value="secret" /> 
    </bean> 

    <bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver"> 
    <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> 
    <property name="prefix" value="/Views/"/> 
    <property name="suffix" value=".jsp"/> 
    </bean> 

    <bean id="entityManagerFactory" 
     class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> 
    <property name="persistenceUnitName" value="EntryPU" /> 
    <property name="dataSource" ref="dataSource" /> 
    <property name="jpaVendorAdapter" ref="jpaVendorAdapter" /> 
    <property name="packagesToScan" value="net.tirasa.jpdaaddressbook" /> 
    </bean> 

    <bean id="jpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> 
    <property name="showSql" value="false" /> 
    <property name="generateDdl" value="false" /> 
    <property name="database" value="MYSQL" /> 
    <property name="databasePlatform" value="org.hibernate.dialect.MySQL5Dialect"/> 
    </bean> 

    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> 
    <!--org.springframework.jdbc.datasource.DataSourceTransactionManager--> 
    <property name="entityManagerFactory" ref="entityManagerFactory" /> 
    </bean> 




    <bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor"/> 

</beans> 

Любые идеи, чтобы найти ошибку? это более полное StackTrace:

Error creating bean with name 'addressBookController': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private net.tirasa.jpaaddressbook.JpaEntryDAO net.tirasa.jpaaddressbook.AddressBookController.dao; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [net.tirasa.jpaaddressbook.JpaEntryDAO] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)} 
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:334) 
+0

Можете ли вы разместить более полную стеклу? – lscoughlin

+1

Программа для интерфейсов не конкретных классов. Вместо 'JpaEntryDAO' в вашем контроллере используйте' EntryDAO'. (В этом весь смысл определять и использовать интерфейс, который вам не нужно знать для класса реализации). –

+0

Почему вы прокомментировали компонент типа 'JpaEntryDAO' в xml? –

ответ

0

Раскоментируйте боб типа JpaEntryDAO в XML.

Смежные вопросы