Транзакционная аннотация не работает

1

Я использую Spring 3.2.8, hibernate 4. У меня есть ошибка "org.springframework.web.util.NestedServletException: Ошибка обработки запроса, вложенное исключение - org.hibernate.HibernateException: createCriteria недействительно без активной транзакции"

web.xml:

<web-app id="WebApp_ID" version="2.4" 
    xmlns="http://java.sun.com/xml/ns/j2ee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee 
    http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

 <display-name>journeys</display-name>

 <servlet>
    <servlet-name>journeys</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>journeys</servlet-name>
        <url-pattern>/</url-pattern>
  </servlet-mapping>

  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>/WEB-INF/journeys-servlet.xml</param-value>
  </context-param>

  <listener>
       <listener-class>
          org.springframework.web.context.ContextLoaderListener
       </listener-class>
  </listener>

  <jsp-config>
    <jsp-property-group>
        <url-pattern>*.jsp</url-pattern>
        <page-encoding>UTF-8</page-encoding>
    </jsp-property-group>
  </jsp-config>
</web-app>

путешествия-servlet.xml:

<beans xmlns="...">
    <context:annotation-config />
    <context:component-scan base-package="journeys.*" />

    <bean id="viewResolver"
        ...
    </bean>

    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="configLocation">
            <value>classpath:hibernate.cfg.xml</value>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLInnoDBDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
    </bean>

    <bean id="dataSource"
        class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://myserver:3306/name" />
        <property name="username" value="user" />
        <property name="password" value="password" />
    </bean>

    <bean id="txManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

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

    <mvc:resources mapping="/resources/**" location="/resources/" />
    <mvc:annotation-driven />
</beans>

класс /hibernate.cfg.xml:

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>
      <!-- Mapping files -->
        <mapping class="journeys.entity.Company"/>
        ....
    </session-factory>
</hibernate-configuration>

CompanyDAO:

package journeys.dao;

import java.util.List;

import org.hibernate.SessionFactory;
import org.hibernate.criterion.Restrictions;

import journeys.utils.Pair;
import journeys.entity.Company;
import journeys.entity.Journey;
import journeys.entity.JourneyDeparture;
import journeys.entity.Order;

@Component
public class CompanyDAO extends AbstractDAO<Company> {
    @Autowired
    private SessionFactory sessionFactory;

    public CompanyDAO() {
        super(Company.class);
    }

    @Transactional
    @SuppressWarnings("unchecked")
    public List<Company> f() {
        return (List<Company>)sessionFactory.getCurrentSession().createCriteria(Company.class).list();
    }
}

CompanyController:

package journeys.controller;

import journeys.dao.CompanyDAO;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;

@Controller
@RequestMapping(value = "/company")
public class CompanyController {    
    @Autowired
    CompanyDAO companydao;

    @RequestMapping(value = {"", "/", "list"}, method = RequestMethod.GET)
    public ModelAndView list() {
        ModelAndView model = new ModelAndView("Company/list");
        model.addObject("companies", companydao.f());

        return model;
    }
}
  • 0
    Попробуйте изменить @Component на @Repository
  • 0
    Пробовал, та же ошибка.
Показать ещё 3 комментария
Теги:
spring
hibernate

2 ответа

7
Лучший ответ

Выполните следующие действия и устраните проблему:

В вашем hibernate.cfg.xml добавьте следующее свойство:

<property name="hibernate.current_session_context_class"> org.springframework.orm.hibernate4.SpringSessionContext
</property>

Также удалите строку <property name="current_session_context_class">thread</property> которая у вас есть в вашем коде

  • 0
    У меня нет current_session_context_class = thread в классе / hibernate.cfg.xml. Но когда я добавил ... SpringSessionContext проблема исчезла, как вы сказали. Спасибо! Это не было очевидным решением.
  • 0
    Да, решение не было очевидным!
0

Общей причиной этого, что я видел, является отсутствие "двигателя" для применения эффекта @Transactional. А именно, в вашем pom вам нужно иметь зависимость времени выполнения от cglib или jaspect. Увидев, как определен ваш tx-менеджер, кажется, вам, скорее всего, понадобится cglib.

Редактировать:

Кроме того, чтобы включить cglib, используйте:

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

а не просто

<tx:annotation-driven transaction-manager="txManager" />
  • 0
    Я использую затмение, а не пом. Я добавил cglib в папку lib и настройки проекта, но ошибка все еще здесь.
  • 0
    @zodiac: я добавил редактирование, которое, я надеюсь, может помочь ...
Показать ещё 2 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню