2017-05-05 12 views
0

새 도메인을 만들고 수동으로 테이블을 만들었습니다. 테이블에 레코드가 하나만 있어야 레코드 ID가 (1)이됩니다.Grails, 레코드를 검색 할 때 캐스팅 오류가 발생했습니다.

레코드가 없으면 자동으로 만들어야하지만 레코드를 검색 할 때 항상 캐스팅 오류가 발생합니다. 수동으로 레코드를 수동으로 작성하면 get, find 또는 항상 오류가 반환되는 것은 중요하지 않습니다. 실패

코드 :

def int id = 1 
    def WtStatus wts = WtStatus.get(id)?:new WtStatus(id:1).save(failOnError:true) 

도메인 :

class WtStatus { 
    def prodBufferService 
    int  weekUpdated 
    Date dateUpdated 

    def beforeInsert() { 
     dateUpdated = new Date() 
     weekUpdated = prodBufferService.getCurrentYearWeek() 
    } 
    def beforeUpdate() { 
     dateUpdated = new Date() 
    } 
    static constraints = { 
     dateUpdated  nullable:true 
     weekUpdated  nullable:true 
    } 

    static mapping = { 
     table 'wt_status' 
     version true 
     id    column: "id",    type:  'int' 
    } 

}

테이블의 생성 스크립트 :

CREATE TABLE [dbo].[wt_status](
    [id] [int] NOT NULL, 
    [version] [bigint] NOT NULL, 
    [date_updated] [datetime2](7) NULL, 
    [week_updated] [int] NULL, 
CONSTRAINT [PK__wt_statu__3213E83F77809FC6] PRIMARY KEY CLUSTERED 
(
    [id] ASC 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY] 

스택 트레이스 :

java.lang.Long cannot be cast to java.lang.Integer. Stacktrace follows: 

java.lang.reflect.InvocationTargetException: null 
    at org.grails.core.DefaultGrailsControllerClass$ReflectionInvoker.invoke(DefaultGrailsControllerClass.java:210) 
    at org.grails.core.DefaultGrailsControllerClass.invoke(DefaultGrailsControllerClass.java:187) 
    at org.grails.web.mapping.mvc.UrlMappingsInfoHandlerAdapter.handle(UrlMappingsInfoHandlerAdapter.groovy:90) 
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:963) 
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:897) 
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) 
    at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861) 
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) 
    at org.springframework.boot.web.filter.ApplicationContextHeaderFilter.doFilterInternal(ApplicationContextHeaderFilter.java:55) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:317) 
    at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:127) 
    at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:91) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:115) 
    at grails.plugin.springsecurity.web.UpdateRequestContextHolderExceptionTranslationFilter.doFilter(UpdateRequestContextHolderExceptionTranslationFilter.groovy:64) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at grails.plugin.springsecurity.web.filter.GrailsAnonymousAuthenticationFilter.doFilter(GrailsAnonymousAuthenticationFilter.groovy:53) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at org.springframework.security.web.authentication.rememberme.RememberMeAuthenticationFilter.doFilter(RememberMeAuthenticationFilter.java:158) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:169) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:200) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at grails.plugin.springsecurity.web.authentication.logout.MutableLogoutFilter.doFilter(MutableLogoutFilter.groovy:62) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:105) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at grails.plugin.springsecurity.web.SecurityRequestHolderFilter.doFilter(SecurityRequestHolderFilter.groovy:58) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:331) 
    at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:214) 
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:177) 
    at org.grails.web.servlet.mvc.GrailsWebRequestFilter.doFilterInternal(GrailsWebRequestFilter.java:77) 
    at org.grails.web.filters.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:67) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 
Caused by: java.lang.ClassCastException: java.lang.Long cannot be cast to java.lang.Integer 
    at org.hibernate.type.descriptor.java.IntegerTypeDescriptor.unwrap(IntegerTypeDescriptor.java:19) 
    at org.hibernate.type.descriptor.sql.IntegerTypeDescriptor$1.doBind(IntegerTypeDescriptor.java:46) 
    at org.hibernate.type.descriptor.sql.BasicBinder.bind(BasicBinder.java:74) 
    at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:253) 
    at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:248) 
    at org.hibernate.loader.Loader.bindPositionalParameters(Loader.java:2051) 
    at org.hibernate.loader.Loader.bindParameterValues(Loader.java:2020) 
    at org.hibernate.loader.Loader.prepareQueryStatement(Loader.java:1950) 
    at org.hibernate.loader.Loader.executeQueryStatement(Loader.java:1903) 
    at org.hibernate.loader.Loader.executeQueryStatement(Loader.java:1881) 
    at org.hibernate.loader.Loader.doQuery(Loader.java:925) 
    at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:342) 
    at org.hibernate.loader.Loader.doList(Loader.java:2622) 
    at org.hibernate.loader.Loader.doList(Loader.java:2605) 
    at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2434) 
    at org.hibernate.loader.Loader.list(Loader.java:2429) 
    at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:109) 
    at org.hibernate.internal.SessionImpl.list(SessionImpl.java:1787) 
    at org.hibernate.internal.CriteriaImpl.list(CriteriaImpl.java:363) 
    at org.hibernate.internal.CriteriaImpl.uniqueResult(CriteriaImpl.java:385) 
    at org.grails.orm.hibernate.AbstractHibernateGormStaticApi$_get_closure1.doCall(AbstractHibernateGormStaticApi.groovy:79) 
    at org.grails.orm.hibernate.GrailsHibernateTemplate.doExecute(GrailsHibernateTemplate.java:243) 
    at org.grails.orm.hibernate.GrailsHibernateTemplate.execute(GrailsHibernateTemplate.java:187) 
    at org.grails.orm.hibernate.GrailsHibernateTemplate.execute(GrailsHibernateTemplate.java:110) 
    at org.grails.orm.hibernate.AbstractHibernateGormStaticApi.get(AbstractHibernateGormStaticApi.groovy:75) 
    at org.grails.datastore.gorm.GormEntity$Trait$Helper.get(GormEntity.groovy:518) 
    at com.buffer.OrdersAndStoreController$$EQIjps9c.list(OrdersAndStoreController.groovy:29) 
    ... 37 common frames omitted 

답변

1

ìd 변수에 사용하려는 유형이 int입니다. 도메인에 id 속성을 선언하지 않았으므로 Long (Grails 기본값)이됩니다. 참고 : 매핑 블록에서는 데이터베이스와의 관계 만 정의하므로 도메인의 속성은 여전히 ​​Long입니다.

또한 변수에 다른 유형을 사용하려는 경우 def을 사용할 필요가 없습니다. 이것을 시도하십시오 :

Long id = 1 
WtStatus wts = WtStatus.get(id)?:new WtStatus(id:1).save(failOnError:true) 
+0

당신이 이드를 선언하는 것에 대해 당신이 말한 것을 보았습니다. 솔루션이 작동하지 않았기 때문에, 나는 여전히 같은 오류가있었습니다. 나는이 ID를 int로 선언하고 모든 것이 작동하기 시작했습니다. – larand

1

너무 복잡해 보입니다. 나는 당신이 정말 원하는 것은 생각 :

WtStatus wts = WtStatus.findOrSaveById(id) 

또한 ref-doc

에 따라, 당신은 Integer 유형이어야하는 id 필드를 정의 explicitelt한다. 그렇지 않으면 GORM은 기본값으로 Long으로 취급합니다.

+0

당신이 말한 것과 똑같은 것을했지만 같은 오류가 있습니다. 위의 수정안을 참조하십시오 : – larand

+0

어떻게 수정했는지 위의 내 의견을 참조하십시오. 코드 스 니펫이 매우 좋습니다. 나는 그것을 지금부터 사용할 것이다. – larand