Liquibase将列的默认值设置为null

5

我尝试使用liquibase的"addDefaultValue"语法将我的列的默认值设置为null:

<changeSet id="20181213171501-2">
    <!-- Add default value -->
    <addDefaultValue tableName="myTable"
        columnDataType="boolean"
        columnName="myColumn"
        defaultValueBoolean="null" />
</changeSet>

但是向myTable插入新行后,发现默认值仍然设置为“false”,与之前一样。因此,liquibase更改集没有起作用。

如何使用liquibase将列的默认值设置为null?


即使该列可为空,删除行defaultValueBoolean="null"会导致liquibase.exception.ValidationFailedException: Validation Failed: defaultValue is required, Default value of null does not match defined type of boolean - RotS
2个回答

2
那就是dropDefaultValue重构所做的:将可空列的默认值重置为null。最初的回答。
<changeSet id="20181213171501-2">
    <!-- Reset default value to NULL -->
    <dropDefaultValue tableName="myTable" columnName="mColumn" />
</changeSet>

1
我找到的解决方案是使用原始的 SQL 查询,而不是 liquibase 的 "addDefaultValue" 语法:
<changeSet id="20181213171501-2">
    <!-- Add default value -->
    <sql dbms="mysql">
        ALTER TABLE myTable MODIFY myColumn BOOLEAN NULL DEFAULT NULL
    </sql>
</changeSet>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接