2012-07-05 3 views
1

저지를 사용하여 안정적인 웹 서비스를 구현 중입니다. hibernate를 사용하여 데이터를 DB에 매핑하는 패키지가 있습니다. 나는이 방법을 사용하여 다음DAO를 사용하여 최대 절전 모드

public class TaskDAO extends GenericDAO<Task> { 

    public TaskDAO() { 
     super(Task.class); 
    } 
} 

: 같은

public abstract class GenericDAO<T> extends DAOFactory { 

    private final Class classe; 

     public GenericDAO(Class classe) { 
      this.classe = classe; 
     } 

      public List<T> findByCriteria(List<Criterion> list) throws Exception { 
       Criteria criteria = getSession().createCriteria(classe); 
       for (int i = 0; i < list.size(); i++) 
        criteria.add(list.get(i)); 
       return criteria.list(); 
      } 
     } 

그런 다음 내 DAO 클래스를 가지고 : 나는 GenericDao 클래스의 방법이

: 나는 DAO를 사용하여 최대 절전 모드에 새로운 오전 서비스 클래스는 다음과 같이 완전히 작동합니다.

public Response get(long projectId, String username) { 
    List<Criterion> list = new ArrayList<Criterion>(); 
    Criterion c = Restrictions.eq("project.id", projectId); 
    list.add(c); 
    List<Deliverable> deliverables = deliverableDAO.findByCriteria(list); 
    return deliverables 
} 

blem 다른 서비스 클래스에이 방법에 : 당신이 "Restrictions.eq 참조로

public Response get(String username) { 
    List<Criterion> list = new ArrayList<Criterion>(); 
    Criterion c = Restrictions.eq("user.username", username); 
    list.add(c); 
    List<Task> tasks = taskDAO.findByCriteria(list); 
    return tasks; 
} 

는 ("project.id을 ", projectId)이"나를 그러나 "Restrictions.eq ("user.username "을 위해 잘 작동, 사용자 이름) "은 아마도 'user.username'과 함께 promelm을 가지고 있습니다.
어떤 도움이 필요합니까? 당신은 변수 'CLASSE'를 사용하고

javax.ws.rs.WebApplicationException: org.hibernate.QueryException: could not resolve property: user.username of: se.softwerk.timelog.model.Task 
    at se.softwerk.controller.services.TaskService.get(TaskService.java:29) 
    at se.softwerk.timelog.controller.TaskManager.taskList(TaskManager.java:72) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at com.sun.jersey.spi.container.JavaMethodInvokerFactory$1.invoke(JavaMethodInvokerFactory.java:60) 
    at com.sun.jersey.server.impl.model.method.dispatch.AbstractResourceMethodDispatchProvider$ResponseOutInvoker._dispatch(AbstractResourceMethodDispatchProvider.java:205) 
    at com.sun.jersey.server.impl.model.method.dispatch.ResourceJavaMethodDispatcher.dispatch(ResourceJavaMethodDispatcher.java:75) 
    at com.sun.jersey.server.impl.uri.rules.HttpMethodRule.accept(HttpMethodRule.java:288) 
    at com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147) 
    at com.sun.jersey.server.impl.uri.rules.ResourceClassRule.accept(ResourceClassRule.java:108) 
    at com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147) 
    at com.sun.jersey.server.impl.uri.rules.RootResourceClassesRule.accept(RootResourceClassesRule.java:84) 
    at com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1469) 
    at com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1400) 
    at com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1349) 
    at com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1339) 
    at com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:416) 
    at com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:537) 
    at com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:708) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:928) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:539) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:298) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 
Caused by: org.hibernate.QueryException: could not resolve property: user.username of: se.softwerk.timelog.model.Task 
    at org.hibernate.persister.entity.AbstractPropertyMapping.propertyException(AbstractPropertyMapping.java:83) 
    at org.hibernate.persister.entity.AbstractPropertyMapping.toColumns(AbstractPropertyMapping.java:98) 
    at org.hibernate.persister.entity.BasicEntityPropertyMapping.toColumns(BasicEntityPropertyMapping.java:61) 
    at org.hibernate.persister.entity.AbstractEntityPersister.toColumns(AbstractEntityPersister.java:1801) 
    at org.hibernate.loader.criteria.CriteriaQueryTranslator.getColumns(CriteriaQueryTranslator.java:522) 
    at org.hibernate.loader.criteria.CriteriaQueryTranslator.findColumns(CriteriaQueryTranslator.java:537) 
    at org.hibernate.criterion.SimpleExpression.toSqlString(SimpleExpression.java:66) 
    at org.hibernate.loader.criteria.CriteriaQueryTranslator.getWhereCondition(CriteriaQueryTranslator.java:419) 
    at org.hibernate.loader.criteria.CriteriaJoinWalker.<init>(CriteriaJoinWalker.java:123) 
    at org.hibernate.loader.criteria.CriteriaJoinWalker.<init>(CriteriaJoinWalker.java:92) 
    at org.hibernate.loader.criteria.CriteriaLoader.<init>(CriteriaLoader.java:93) 
    at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1464) 
    at org.hibernate.internal.CriteriaImpl.list(CriteriaImpl.java:374) 
    at se.softwerk.timelog.model.dao.GenericDAO.findByCriteria(GenericDAO.java:33) 
    at se.softwerk.controller.services.TaskService.get(TaskService.java:24) 
+0

stacktrace 게시 하시겠습니까? – WeMakeSoftware

+0

첫 번째 답변을 업데이트했습니다. 당신은 조언을 따르고 다음과 같은 것을 추가해야합니다 : createAlias ​​("user", "user") – WeMakeSoftware

답변

0

의 해당 섹션을 읽어 보시기 바랍니다 프로젝트의 ID가 외래 키로서 태스크 테이블에 직접 저장되기 때문에 태스크의 프로젝트 ID.

디자인 노트 : DAO는 많은 가치를 부여하지 않습니다. 특히, 서비스 클래스를 지속성 API (이 경우에는 Hibernate)와 분리하지 않습니다. 당신은 서비스 클래스에서 Hibernate 세션을 직접 사용할 수있다. DAO를 지속성 논리를

  • 을 포함하면서 순서대로 DAO를 조롱 수 있으며, 서비스 클래스는 비즈니스 로직을 포함

    • 그것이 책임 명확하게 : 완전히 지속성 API에서 서비스 클래스를 분리하는 것은 두 가지 이유에서 유용합니다 서비스를 단위 테스트하는 것.
  • +0

    감사합니다. 나는 DAO를 사용하고있다. "코드를 관리 할 수있는 계층으로 분리해야한다. 모든 절전 모드 코드가 다른 클래스와 섞여 있다면, 모든 것을 변경하는 단일 변경을하기가 어렵다. 대신에 1 클래스 (dao)는 하나의 객체 또는 객체 그룹에 대한 데이터 액세스를 관리합니다. 캡슐화의 객체 지향 원칙을 따르므로 DAO를 서비스 계층 (저지)에 "연결"하고 CRUD 작업을 DAO " – Ali

    +0

    에 위임합니다. 자세한 내용은이 링크를 확인하십시오. http://stackoverflow.com/questions/11190934/rest-with-java-jax-rs-using-jersey – Ali

    +0

    DAO를 사용할 필요가 없다고 생각합니까? – Ali

    0

    : 같은

    스택 추적의 오류입니다. 이게 뭐야? 정의를 보여주십시오.

    특정 클래스에 대한 Criteria 인스턴스를 작성해야합니다. 때문에,

    public Response get(String username) { 
        List<Criterion> list = new ArrayList<Criterion>(); 
        Criterion c = Restrictions.eq("user.username", username); 
        list.add(c); 
        //this will create an alias 
        List<Task> tasks = taskDAO.findByCriteria(Task.class, list); 
        return tasks; 
    } 
    

    당신은 당신의 코드를 재 설계해야합니다

    public List<T> findByCriteria(Class<?> askFor, List<Criterion> list) throws Exception { 
         Criteria criteria = getSession().createCriteria(askFor); 
         for (int i = 0; i < list.size(); i++) 
          criteria.add(list.get(i)); 
         return criteria.list(); 
        } 
    

    을 나중에 같이 사용 : 당신이 사용자 개체의 목록을 반환하려는 경우, 당신은이처럼 보이도록 코드를 리팩토링한다 달성하려는 것은 Task.user.username에 대한 별칭 기준을 만드는 것입니다. 당신은 할 필요가 없습니다

    criteria.createAlias("user", "theUser"); 
    criteria.add(Restrictions.eq("theUser.username", username); 
    

    : 수동 (15.4) http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/querycriteria.html 당신은이 작업의 사용자에 필드에 액세스 할 수 있도록 참여 만들 필요가

    +0

    고맙습니다. classe의 정의가 무엇인지 확인해주십시오.분명히 당신이 생각했던 것과 똑같습니다. 무슨 abuot project.id? 왜 그게 효과가 있니? – Ali

    +0

    문제는 createAlias ​​("user", "user")로 해결되지만 현재 코드로 추가 할 수있는 장소가 없습니다. – WeMakeSoftware