java - Grails 中的一对多映射 |我可以在组合键中使用生成的值吗?

标签 java grails one-to-many

我有两个表:CompanyRatingRatingMeasure

CompanyRating 将与 RatingMeasure 进行一对多映射

这是我的域类:

package com.cedar.ts.bbk

import java.io.Serializable;

class CompanyRating implements Serializable {
    private static final long serialVersionUID = -6435485664486973464L;

    String cmpName
    String bbkRating
    String understanding
    java.sql.Date reportDate
    String analystComments

    List<RatingMeasure> measures = new ArrayList<RatingMeasure>();

    static hasMany = [measures: RatingMeasure]

    static constraints = {
        cmpName(blank:true)
        bbkRating(blank:true)
        understanding(blank:true)
        reportDate(blank:true)
        analystComments(blank:true)
    }

    static mapping = {
        id generator:'hilo', params:[table:'hi_value',column:'next_value',max_lo:100]
        table 'CMP_RATING'
        version false
        cmpName column:'CMPNAME'
        bbkRating column:'BBKRATING'
        understanding column:'UNDERSTANDING'
        reportDate column:'REPORTDATE'
        analystComments column:'ANALYSTCOMMENTS'
    }

    def String toString(){
        return cmpName ; //+ " " + bbkRating +" " + understanding  +" " + analystComments +" " +  measures;
    }
}


package com.cedar.ts.bbk

class RatingMeasure implements Serializable{
    private static final long serialVersionUID = -6435485664486973464L;

    Integer measureID
    String measure
    String keyRatios
    String company
    String targetValue
    String indicatorDirection
    CompanyRating companyRating

    static belongsTo = [companyRating:CompanyRating]

    static constraints = {
        measureID(blank:true)
        measure(blank:true)
        measure(blank:true)
        keyRatios(blank:true)
        company(blank:true)
        targetValue(blank:true)
        indicatorDirection(blank:true)
    }

    static mapping = {
        table 'RATING_MEASURE'
        version false
        measureID column:'MSR_ID'
        measure column:'MEASURE'
        keyRatios column:'KEYRATIOS'
        company column:'COMPANY'
        targetValue column:'TARGETVALUE'
        indicatorDirection column:'INDICATORDIRECTION'
        companyRating column:'CMP_ID'

        measureID generator:'hilo', params:[table:'hi_value',column:'next_value',max_lo:100]
        id composite:['measureID', 'companyRating'], generator: "assigned"
    }

    def String toString(){
        return measure;
    }
}

相应的RatingMeasure表-RATING_MEASURE具有复合主键。 其中一个键(measureID)是自动生成的。

但是,当我尝试保存时,出现以下错误:

Property [{0}] of class [{1}] cannot be null
[Field error in object 'com.cedar.ts.bbk.CompanyRating' on field 'measures.measureID': rejected value [null];,nullable.com.cedar.ts.bbk.CompanyRating.measures.measureID,nullable.measures.measureID,nullable.measureID,nullable]; arguments [measureID,class com.cedar.ts.bbk.RatingMeasure]; default message [Property [{0}] of class [{1}] cannot be null]]

我做错了什么?我希望自动分配 measureID

最佳答案

这里真的有必要使用复合 id 吗?如果您将measureId与hilo生成器一起使用,它已经是唯一的并且是pk的不错选择,因此我认为不需要复合键。

关于java - Grails 中的一对多映射 |我可以在组合键中使用生成的值吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5963818/

相关文章:

grails - gorm继承导致DuplicateMappingException

java - org.hibernate.AnnotationException : Use of @OneToMany or @ManyToMany targeting an unmapped class

java - 如何在@Query注释中获取特定城市及其所有相关学校

java - java中优雅的最小/最大绝对值

grails - 使用 createcriteria 嵌套对象属性查找列表

java - 快要疯了;如何从适配器内设置OnclickListener?

grails - 在哪里可以找到所有 Grails 字段插件类型的默认模板?

mysql - 在 mysql 数据库中存储友谊协会的正确方法是什么

java - 动态调用非静态方法

java - 带有 IntelliJ 的 super 开发模式 GWT