2013-08-13 2 views
1

나는 Spring을 Hibernate와 함께 사용하고 있으며, 원래 프로젝트를 설정했다. with a hibernate xml config, 이는 성능상의 문제를 가져 왔고, 잘못된 방법으로 보였다. 나는 이제 1 DAO로 시작하는 SessionFactory를 주입하려고 시도하지만, sessionFactory.getCurrentSession()이 호출되는 널 포인터 예외를 얻는다. 내 코드는 내가 본 예제처럼 보입니다. 나는 혼란 스럽다. 나는 또한 리소스를 사용하지 않고 sessionFactory를 애플리케이션 컨텍스트의 dao에 주입하려고 시도했다. 같은 결과.SessionFactory is null

ApplicationContext.xml

<context:component-scan base-package="path.to.base"> 
    <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> 
</context:component-scan> 

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> 
    <property name="dataSource" ref="dataSource" /> 
    <property name="mappingDirectoryLocations"> 
     <list> 
      <value>classpath*:/path/to/mapping/files</value> 
     </list> 
    </property> 
    <property name="hibernateProperties"> 
     <props> 
      <prop key="dialect">org.hibernate.dialect.Oracle10gDialect</prop> 
      <prop key="hibernate.show_sql">true</prop> 
     </props> 
    </property> 
</bean> 
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> 
    <property name="sessionFactory" ref="sessionFactory"/> 
</bean> 

<tx:annotation-driven/> 

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> 
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" /> 
    <property name="url" value="${jdbc.url}" /> 
    <property name="username" value="${jdbc.username}" /> 
    <property name="password" value="${jdbc.password}" /> 
</bean> 

myDAO

@Repository 
public class myDAO { 
private SessionFactory sessionFactory; 

public SessionFactory getSessionFactory(){ 
    return sessionFactory; 
} 

@Resource(name="sessionFactory") 
public void setSessionFactory(SessionFactory sessionFactory) { 
    this.sessionFactory = sessionFactory; 
} 

public myDAO() { 

} 

@SuppressWarnings("unchecked") 
@Transactional(readOnly=true) 
public List<Things> getAllThings() { 
    return sessionFactory.getCurrentSession().createCriteria(EvalMasterEvaluationType.class) 
      .add(Restrictions.eq("active", "Y")).addOrder(Order.desc("createDtTm")).list(); 

} 

}

봄 3.2.1, 나는 그것이 작동있어 3.6.10

+0

데이터 소스가 나는 비슷한 문제가 건너했다 제대로 –

+1

설정되어 있지 않습니다. 데이터 소스가 올바로 설정되지 않았기 때문입니다. –

+0

그럴 것 같지 않습니다. 내 데이터 소스에있는 속성이 누락되지 않았으며 드라이버, URL, 사용자 이름 및 암호가 정확하다는 것을 알고 있습니다. 다른 수업을 시도했지만 도움이되지 않았습니다. 그래도이 파일들 밖에서 뭔가있을 수 있습니다. –

답변

0

아니에요하지만, 최대 절전 모드 어떤 수정이 문제를 해결했는지 확인하십시오. SRT_KP는 일부 속성 (maxactive, maxidle, validationquery)을 추가 한 이후 데이터 소스에 관한 것일 수 있습니다. 내가 XML 매핑을 사용하고 있으며 매핑 파일 접미사를 mappingLocations 속성에 추가 했으므로 LocalSessionFactoryBean으로 전환했습니다. 또한 @Transactional을 속한 서비스 계층으로 이동했습니다.

는 여기에 내가 함께 결국 무엇을 :

<?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:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd 
     http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd 
     http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd 
     http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd"> 

<context:property-placeholder location="classpath*:WEB-INF/*.properties"/> 
<context:component-scan base-package="org.base.to.scan"> 
    <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> 
</context:component-scan> 



<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> 
    <property name="dataSource" ref="oraDataSource" /> 
    <property name="mappingLocations" value="classpath*:org/path/to/mapping/files/*.hbm.xml" /> 
</bean> 

<bean id="oraDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> 
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" /> 
    <property name="url" value="${jdbc.url}" /> 
    <property name="username" value="${jdbc.username}" /> 
    <property name="password" value="${jdbc.password}" /> 
    <property name="maxActive" value="10" /> 
    <property name="maxIdle" value="5" /> 
    <property name="validationQuery" value="SELECT 'x' FROM dual" /> 
</bean> 

<tx:annotation-driven/> 

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

BTW 큰 튜토리얼 : http://www.byteslounge.com/tutorials/spring-with-hibernate-persistence-and-transactions-example