Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/google-sheets/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Grails 为什么更改域中的映射属性不会';不能生成新的变更记录行吗?_Grails_Database Migration_Changelog - Fatal编程技术网

Grails 为什么更改域中的映射属性不会';不能生成新的变更记录行吗?

Grails 为什么更改域中的映射属性不会';不能生成新的变更记录行吗?,grails,database-migration,changelog,Grails,Database Migration,Changelog,添加后,域如下所示: class Donation { BigDecimal amount static constraints = { amount min: BigDecimal.ZERO } static mapping = { } } 进行更改后,我在grails控制台中运行了dbm gorm diff,但它没有打印额外的更改日志行。我想知道进行映射更改是否不会产生新的changelog行。但从mysql数据库中“amou

添加后,域如下所示:

class Donation {

    BigDecimal amount

    static constraints = {
        amount min: BigDecimal.ZERO
    }

    static mapping = {
    }

}

进行更改后,我在grails控制台中运行了dbm gorm diff,但它没有打印额外的更改日志行。我想知道进行映射更改是否不会产生新的changelog行。但从mysql数据库中“amount”的数据类型来看,它显示为decimal(19,2)。我认为制作scale4会将数据类型更改为decimal(19,4)。我很感激在这个进退两难的困境中得到的任何帮助。谢谢

而数据库迁移可以检测域中的更改,并生成所需的更改日志以更新数据库架构。始终定位正确的更改是不够明智的。特别是在重命名表/列或更改列的数据类型时。在这种情况下,您需要进行manula迁移

手动更改日志以使用db迁移更新架构:

class Donation {

    BigDecimal amount       

    static constraints = {
        amount min: BigDecimal.ZERO
    }

    static mapping = {
        amount scale: 4
    }

}

因此,在生成变更日志之后,始终要验证它是否包含正确的变更

+1,并添加一些自动测试。您确实有针对迁移后结构运行的域测试,以验证迁移是否正确,不是吗???
databaseChangeLog = {

    changeSet(author: "sandeep (manual)", id: "20150901124635-01") {
        modifyDataType(columnName: "amount", newDataType: "decimal(19,4)", tableName: "donation")
    }
}